:root{--cream:#FAF7EF;--cream-2:#F3EEE1;--paper:#FFFFFF;--navy:#15263F;--navy-2:#1E3252;--navy-soft:#27405f;--gold:#C7A24A;--gold-soft:#d8bd7d;--gold-deep:#B98900;--blue:#2E6B9E;--blue-deep:#24557e;--blue-bg:#EAF1F7;--ink:#1A2A40;--muted:#5E6B7C;--line:#E4DDCC;--line-2:#Eceae3;--rust:#A8643C;--green:#3E8E5A;--green-bg:#E9F3EC;--red:#B5483B;--amber-bg:#FBF3E0}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Hiragino Kaku Gothic ProN,Yu Gothic,Meiryo,sans-serif;color:var(--ink);background:var(--cream-2);line-height:1.7;-webkit-font-smoothing:antialiased}.serif{font-family:Hiragino Mincho ProN,Yu Mincho,serif}a{color:inherit;text-decoration:none}.page{min-height:100vh;flex-direction:column;padding:24px 16px 60px}.caption-bar,.page{display:flex;align-items:center}.caption-bar{width:100%;max-width:1180px;gap:14px;margin-bottom:22px;color:var(--muted);font-size:14px}.caption-bar a{color:var(--blue);font-weight:600}.caption-bar .sep{color:var(--line)}.caption-bar b{color:var(--ink)}.screen-caption{margin-top:18px;color:var(--muted);font-size:14px;text-align:center;max-width:520px}.screen-title{margin-top:14px;font-weight:700;font-size:20px;color:var(--navy);text-align:center}.device{width:390px;max-width:100%;background:#0e1626;border-radius:42px;padding:12px;box-shadow:0 30px 70px rgba(21,38,63,.28)}.device-screen{background:var(--cream);border-radius:32px;overflow:hidden;height:780px;display:flex;flex-direction:column;position:relative}.device-scroll{overflow-y:auto;flex:1 1}.device-scroll::-webkit-scrollbar{width:0}.appbar{background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:space-between;padding:14px 18px;flex:none}.appbar .brand{display:flex;align-items:baseline;gap:7px}.appbar .brand .k{font-family:Hiragino Mincho ProN,Yu Mincho,serif;font-weight:700;font-size:18px}.appbar .brand .r{font-size:9px;letter-spacing:.28em;color:var(--gold-soft)}.appbar .meta{font-size:10.5px;color:#9fb0c4;display:flex;align-items:center;gap:5px}.appbar.mode-admin .brand .r,.appbar.mode-family .brand .r{color:var(--gold-soft)}.appbar .tag-mode{font-size:10px;color:#cdd7e4;border:1px solid rgba(255,255,255,.25);border-radius:20px;padding:2px 9px;margin-left:6px}.backrow{padding:12px 18px 0}.backrow a{color:var(--blue);font-size:13px;font-weight:600}.body{padding:18px 18px 28px}.h-lead{display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px;margin:8px 0 18px}.h-lead .ic{width:46px;height:46px;border-radius:50%;background:var(--cream-2);display:grid;place-items:center;font-size:22px;color:var(--gold-deep);margin-bottom:2px}.h-lead h1{font-size:19px;font-weight:700;color:var(--navy)}.h-lead p{font-size:12.5px;color:var(--muted);max-width:280px}.page-head{margin-bottom:14px}.page-head .eye{font-size:11px;color:var(--blue);font-weight:700;letter-spacing:.04em}.page-head h1{font-size:20px;font-weight:700;color:var(--navy);display:flex;align-items:center;gap:8px}.page-head .sub{font-size:12px;color:var(--muted);margin-top:3px}.field{margin-bottom:14px}.label{display:block;font-size:12px;font-weight:600;color:var(--ink);margin-bottom:5px}.input,.select,.textarea{width:100%;border:1px solid var(--line);background:var(--paper);border-radius:11px;padding:11px 13px;font-size:13.5px;color:var(--ink);font-family:inherit}.input::placeholder,.textarea::placeholder{color:#aab3bf}.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--blue)}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%);background-position:calc(100% - 18px) 17px,calc(100% - 13px) 17px;background-size:5px 5px,5px 5px;background-repeat:no-repeat}.textarea{min-height:84px;resize:vertical;line-height:1.6}.hint{font-size:11px;color:var(--muted);margin-top:4px}.mask{letter-spacing:2px}.note{border-radius:11px;padding:11px 13px;font-size:11.5px;line-height:1.6;margin:6px 0 14px}.note .nt{font-weight:700}.note-info,.note-lock{background:var(--blue-bg);color:var(--blue-deep)}.note-lock{display:flex;gap:8px;align-items:flex-start}.note-warn{background:var(--amber-bg);color:#8a6a1e}.note-soft{background:var(--cream-2);color:var(--muted)}.note-ok{background:var(--green-bg);color:var(--green)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;border:none;cursor:pointer;font-family:inherit;font-weight:700;font-size:14px;border-radius:12px;padding:13px 18px;transition:.15s}.btn-primary{background:var(--blue);color:#fff}.btn-primary:hover{background:var(--blue-deep)}.btn-gold{background:var(--gold);color:#2a2206}.btn-gold:hover{filter:brightness(1.05)}.btn-outline{background:var(--paper);color:var(--navy);border:1.5px solid var(--line)}.btn-ghost{background:transparent;color:var(--muted)}.btn-block{display:flex;width:100%}.btn-lg{padding:15px 18px;font-size:15px}.btn-row{display:flex;gap:10px}.btn-row .btn{flex:1 1}.add-row{width:100%;border:1px dashed var(--line);background:transparent;color:var(--blue);border-radius:11px;padding:11px;font-size:12.5px;font-weight:600;cursor:pointer;margin-bottom:10px}.card{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:14px;margin-bottom:12px}.card.dark{background:var(--navy);color:#fff;border-color:var(--navy)}.card.dark .c-sub{color:#bccadb}.section-label{font-size:11px;font-weight:700;color:var(--muted);letter-spacing:.06em;margin:16px 0 8px}.c-title{font-size:14px;font-weight:700}.c-sub{font-size:11.5px;color:var(--muted)}.summary{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:13px 15px;display:flex;align-items:center;gap:12px;margin-bottom:8px}.summary .ring{width:40px;height:40px;border-radius:50%;background:var(--cream-2);display:grid;place-items:center;color:var(--gold-deep);font-size:18px;flex:none}.summary .s-main{flex:1 1}.summary .s-main .t{font-size:13px;font-weight:700}.summary .s-main .d{font-size:11px;color:var(--muted)}.cat-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:10px;gap:10px}.cat{background:var(--paper);border:1px solid var(--line);border-radius:13px;padding:12px;text-align:left;display:flex;flex-direction:column;gap:5px;cursor:pointer}.cat:hover{border-color:var(--gold)}.cat .ci{font-size:18px}.cat .cn{font-size:13px;font-weight:700;color:var(--navy)}.cat .cd{font-size:10.5px;color:var(--muted);line-height:1.4}.cat .cc{font-size:10px;color:var(--blue);font-weight:700;margin-top:2px}.list{background:var(--paper);border:1px solid var(--line);border-radius:14px;overflow:hidden;margin-bottom:12px}.list-row{display:flex;align-items:center;gap:11px;padding:13px 14px;border-bottom:1px solid var(--line-2)}.list-row:last-child{border-bottom:none}.list-row .ic{width:30px;height:30px;border-radius:9px;background:var(--cream-2);display:grid;place-items:center;font-size:15px;flex:none;color:var(--gold-deep)}.list-row .lr-main{flex:1 1;min-width:0}.list-row .lr-main .t{font-size:13px;font-weight:700}.list-row .lr-main .d{font-size:11px;color:var(--muted)}.list-row .chev{color:#c3ccd6;font-size:16px}.list-row .deadline{font-size:10.5px;font-weight:700;color:var(--rust);white-space:nowrap}button.list-row{width:100%;border:0;border-bottom:1px solid var(--line-2);background:transparent;font:inherit;color:inherit;text-align:left;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}button.list-row:hover{background:var(--cream-2)}button.list-row:last-child{border-bottom:none}.lock-overlay{position:fixed;inset:0;z-index:2000;background:rgba(245,243,239,.97);display:flex;align-items:center;justify-content:center;padding:20px}.lock-card{background:var(--paper);border:1px solid var(--line);border-radius:16px;max-width:380px;width:100%;padding:26px 22px;text-align:center;box-shadow:0 14px 44px rgba(21,38,63,.18)}.lock-card .lock-ic{font-size:34px;line-height:1}.lock-card h2{font-size:21px;color:#15263F;margin:10px 0 8px}.lock-card p{font-size:15.5px;color:var(--ink);line-height:1.85;margin:0 0 18px}.lock-card .lock-logout{display:inline-block;margin-top:14px;font-size:13.5px;font-weight:600;color:var(--blue);background:none;border:none;cursor:pointer}.lock-card .lock-logout:disabled{opacity:.5;cursor:default}.toast-wrap{position:fixed;left:0;right:0;bottom:20px;z-index:1000;flex-direction:column;gap:8px;padding:0 14px;pointer-events:none}.toast,.toast-wrap{display:flex;align-items:center}.toast{pointer-events:auto;gap:9px;max-width:520px;width:100%;border-radius:12px;padding:11px 13px;font-size:13px;font-weight:600;line-height:1.4;box-shadow:0 8px 24px rgba(21,38,63,.18);border:1px solid transparent;animation:toast-in .18s ease-out}.toast .toast-ic{flex:none;font-weight:800}.toast .toast-text{flex:1 1;min-width:0}.toast .toast-x{flex:none;border:none;background:transparent;cursor:pointer;font-size:18px;line-height:1;color:inherit;opacity:.6;padding:0 2px}.toast .toast-x:hover{opacity:1}.toast-ok{background:var(--green-bg);border-color:#CCE3D2;color:#256B41}.toast-warn{background:#F6E7E5;border-color:#E2C9C5;color:#8E3F38}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.badge{display:inline-block;font-size:10px;font-weight:700;border-radius:20px;padding:2px 9px}.badge-gold{background:var(--cream-2);color:var(--gold-deep)}.badge-blue{background:var(--blue-bg);color:var(--blue-deep)}.badge-green{background:var(--green-bg);color:var(--green)}.badge-grey{background:#EEF0F2;color:var(--muted)}.badge-red{background:#F6E7E5;color:var(--red)}.steps{display:flex;flex-direction:column;gap:9px;margin:6px 0 16px}.step{display:flex;align-items:center;gap:12px;background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:12px 13px}.step .sn{width:24px;height:24px;border-radius:50%;background:var(--cream-2);color:var(--blue-deep);display:grid;place-items:center;font-size:12px;font-weight:700;flex:none}.step .st .t{font-size:13px;font-weight:700}.step .st .d{font-size:11px;color:var(--muted)}.otp{display:flex;gap:8px;justify-content:space-between;margin:8px 0}.otp input{width:100%;aspect-ratio:1/1.15;text-align:center;font-size:18px;font-weight:700;border:1px solid var(--line);border-radius:10px;background:var(--paper)}.otp input:focus{outline:none;border-color:var(--blue)}.divider{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:11px;margin:14px 0}.divider:after,.divider:before{content:"";height:1px;background:var(--line);flex:1 1}.toggle-row{display:flex;align-items:center;gap:11px;padding:11px 0;border-bottom:1px solid var(--line-2)}.toggle-row:last-child{border-bottom:none}.toggle-row .tg-main{flex:1 1}.toggle-row .tg-main .t{font-size:13px;font-weight:600}.toggle-row .tg-main .d{font-size:10.5px;color:var(--muted)}.switch{width:40px;height:23px;border-radius:20px;background:var(--blue);position:relative;flex:none}.switch.off{background:#cbd3db}.switch:after{content:"";position:absolute;top:2px;left:2px;width:19px;height:19px;border-radius:50%;background:#fff;transition:.15s}.switch.off:after{left:auto;right:2px}.plan{border:1px solid var(--line);border-radius:16px;padding:18px;background:var(--paper);margin-bottom:12px}.plan.feature{background:var(--navy);color:#fff;border-color:var(--navy);position:relative;overflow:hidden}.plan .pk{font-size:11px;font-weight:700;color:var(--blue)}.plan.feature .pk{color:var(--gold-soft)}.plan .pn{font-weight:700;font-size:16px;margin:2px 0 6px}.plan .pa{font-size:26px;font-weight:800;font-family:Hiragino Mincho ProN,serif}.plan .pa small{font-size:12px;font-weight:500;color:var(--muted)}.plan.feature .pa small{color:#aebccd}.plan ul{list-style:none;margin:10px 0 14px}.plan li{font-size:12px;padding:5px 0 5px 20px;position:relative}.plan li:before{content:"✓";position:absolute;left:0;color:var(--gold);font-weight:700}.letter{background:#fffdf7;border:1px solid var(--line);border-radius:14px;padding:20px;font-family:Hiragino Mincho ProN,Yu Mincho,serif;font-size:13.5px;line-height:2;color:#2b2b2b;white-space:pre-line}.letter .sign{text-align:right;margin-top:14px;color:var(--muted)}.tabs{display:flex;gap:6px;background:var(--cream-2);padding:4px;border-radius:11px;margin-bottom:12px}.tab{flex:1 1;text-align:center;font-size:11.5px;font-weight:600;padding:7px;border-radius:8px;color:var(--muted);cursor:pointer}.tab.active{color:var(--navy);box-shadow:0 1px 3px rgba(0,0,0,.06)}.tab.active,.upload{background:var(--paper)}.upload{border:1.5px dashed var(--line);border-radius:14px;padding:26px 16px;text-align:center;margin-bottom:12px}.upload .ui{font-size:24px;color:var(--blue)}.upload .ut{font-size:13px;font-weight:700;margin-top:8px}.upload .ud{font-size:11px;color:var(--muted)}.file-row{display:flex;align-items:center;gap:10px;background:var(--paper);border:1px solid var(--line);border-radius:11px;padding:11px 13px;margin-bottom:12px}.file-row .fi{font-size:18px;color:var(--blue)}.file-row .fm{flex:1 1}.file-row .fm .t{font-size:12.5px;font-weight:700}.file-row .fm .d{font-size:10.5px;color:var(--muted)}.file-row .ok{color:var(--green)}.approver{display:flex;align-items:center;gap:11px;padding:12px 0;border-bottom:1px solid var(--line-2)}.approver:last-child{border-bottom:none}.approver .av{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;font-size:13px;flex:none}.approver .av.done{background:var(--green-bg);color:var(--green)}.approver .av.wait{background:#EEF0F2;color:var(--muted)}.approver .ap-main{flex:1 1}.approver .ap-main .t{font-size:13px;font-weight:700}.approver .ap-main .d{font-size:11px;color:var(--muted)}.admin{width:100%;max-width:1180px;background:var(--paper);border:1px solid var(--line);border-radius:16px;overflow:hidden;display:flex;min-height:660px;box-shadow:0 20px 50px rgba(21,38,63,.12)}.sidebar{width:218px;background:var(--navy);color:#cdd7e4;flex:none;padding:18px 12px}.sidebar .brand{display:flex;align-items:baseline;gap:7px;padding:6px 10px 16px}.sidebar .brand .k{font-family:Hiragino Mincho ProN,serif;font-weight:700;font-size:19px;color:#fff}.sidebar .brand .r{font-size:9px;letter-spacing:.26em;color:var(--gold-soft)}.sidebar .nav-sec{font-size:10px;color:#7d8ca0;letter-spacing:.08em;padding:12px 10px 4px}.sidebar a{display:flex;align-items:center;gap:9px;padding:9px 10px;border-radius:9px;font-size:13px;color:#cdd7e4}.sidebar a:hover{background:rgba(255,255,255,.06);color:#fff}.sidebar a.active{background:var(--blue);color:#fff}.sidebar a .si{width:18px;text-align:center}.admin-main{flex:1 1;display:flex;flex-direction:column;min-width:0;background:var(--cream)}.topbar{display:flex;align-items:center;justify-content:space-between;padding:15px 22px;background:var(--paper);border-bottom:1px solid var(--line)}.topbar h1{font-size:18px;font-weight:700;color:var(--navy)}.topbar .tb-right{gap:12px;font-size:12px;color:var(--muted)}.topbar .tb-right,.topbar .who{display:flex;align-items:center}.topbar .who{gap:7px}.topbar .who .av{width:28px;height:28px;border-radius:50%;background:var(--navy);color:#fff;display:grid;place-items:center;font-size:11px}.admin-body{padding:22px;overflow:auto}.zk-banner{background:var(--blue-bg);color:var(--blue-deep);border-radius:10px;padding:10px 14px;font-size:12px;margin-bottom:18px;display:flex;gap:8px;align-items:flex-start}.kpi-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:14px;gap:14px;margin-bottom:18px}.kpi{background:var(--paper);border:1px solid var(--line);border-radius:13px;padding:15px 16px}.kpi .kl{font-size:11.5px;color:var(--muted)}.kpi .kv{font-size:26px;font-weight:800;color:var(--navy);margin-top:3px}.kpi .kc{font-size:11px;font-weight:700;margin-top:2px}.kpi .kc.up{color:var(--green)}.kpi .kc.warn{color:var(--rust)}.panel{background:var(--paper);border:1px solid var(--line);border-radius:13px;margin-bottom:18px;overflow:hidden}.panel-h{padding:13px 16px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}.panel-h h2{font-size:14px;font-weight:700;color:var(--navy)}.panel-b{padding:16px}table.tbl{width:100%;border-collapse:collapse;font-size:12.5px}table.tbl th{text-align:left;background:var(--cream-2);color:var(--muted);font-weight:700;padding:9px 12px;font-size:11.5px;border-bottom:1px solid var(--line)}table.tbl td{padding:10px 12px;border-bottom:1px solid var(--line-2);color:var(--ink)}table.tbl tr:last-child td{border-bottom:none}table.tbl tr:hover td{background:#fbfaf6}.adm-grid-2{display:grid;grid-template-columns:1fr 1fr;grid-gap:18px;gap:18px}.adm-grid-3{display:grid;grid-template-columns:2fr 1fr;grid-gap:18px;gap:18px}.field-mini{margin-bottom:12px}.field-mini .label{font-size:11.5px}.search{display:flex;gap:8px;margin-bottom:14px}.search input{flex:1 1;border:1px solid var(--line);border-radius:10px;padding:9px 12px;font-size:13px;font-family:inherit}.kv-row{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--line-2);font-size:12.5px}.kv-row:last-child{border-bottom:none}.kv-row .k{color:var(--muted)}.kv-row .v{font-weight:600}@media(max-width:820px){.admin{flex-direction:column}.sidebar{display:flex;flex-wrap:wrap;gap:4px}.sidebar,.sidebar .nav-sec{width:100%}.kpi-grid{grid-template-columns:1fr 1fr}.adm-grid-2,.adm-grid-3{grid-template-columns:1fr}}.mgrid{display:grid;grid-template-columns:1fr 1fr;grid-gap:10px;gap:10px;margin-bottom:12px}.mitem{background:var(--paper);border:1px solid var(--line);border-radius:12px;overflow:hidden}.mthumb{height:92px;display:grid;place-items:center;font-size:26px;color:#fff;position:relative;overflow:hidden}.mthumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.p1{background:#8FB0C9}.p2{background:#C9A98F}.p3{background:#9CBFA6}.p4{background:#B79FC4}.mmeta{padding:8px 10px}.mmeta .mn{font-size:11.5px;font-weight:700;color:var(--navy);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mmeta .md{font-size:10px;color:var(--muted);margin-top:1px}.mmeta .to{font-size:10px;color:var(--green);font-weight:700;margin-top:3px}.tl{position:relative;margin:4px 0;padding-left:30px}.tl:before{content:"";position:absolute;left:11px;top:6px;bottom:6px;width:2px;background:var(--line)}.tl-item{position:relative;margin-bottom:12px}.tl-item .num{position:absolute;left:-30px;top:0;width:24px;height:24px;border-radius:50%;background:var(--navy);color:#fff;display:grid;place-items:center;font-size:11px;font-weight:700}.tl-card{background:var(--paper);border:1px solid var(--line);border-radius:13px;padding:12px 13px}.tl-card .t{font-size:13.5px;font-weight:700;color:var(--navy)}.tl-card .d{font-size:11.5px;color:var(--muted);margin:3px 0 8px;line-height:1.6}.tl-card .see{font-size:11.5px;font-weight:700;color:var(--blue)}.tag-soft{display:inline-block;font-size:10px;font-weight:700;color:var(--gold-deep);background:var(--cream-2);border-radius:20px;padding:2px 9px;margin-bottom:6px}.dec-row{display:flex;justify-content:space-between;gap:10px;padding:7px 0;border-bottom:1px solid var(--line-2);font-size:12.5px}.dec-row:last-child{border-bottom:none}.dec-row .k{color:var(--muted);flex:none}.dec-row .v{font-weight:600;text-align:right;word-break:break-all;white-space:pre-wrap}.appshell{max-width:430px;margin:0 auto;min-height:100vh;background:var(--cream);display:flex;flex-direction:column}.appshell .device-scroll{flex:1 1}@media(min-width:700px){.appshell{zoom:1.4;max-width:min(640px,calc((100vw - 56px)/1.4));min-height:calc((100vh - 84px)/1.4);margin:32px auto;border:1px solid var(--line);border-radius:22px;overflow:hidden;box-shadow:0 12px 34px rgba(21,38,63,.1)}.appshell .appbar{padding:15px 30px}.appshell .backrow{padding:14px 30px 0}.appshell .body{padding:24px 30px 36px}.appshell .cat-grid{gap:12px}.appshell .cat-grid,.appshell .mgrid{grid-template-columns:repeat(3,1fr)}.appshell .h-lead p{max-width:440px}.appshell .otp{max-width:380px;margin-left:auto;margin-right:auto}}@media(min-width:1280px){.appshell{zoom:1.55;max-width:min(760px,calc((100vw - 64px)/1.55));min-height:calc((100vh - 86px)/1.55)}.appshell .mgrid{grid-template-columns:repeat(4,1fr)}}@media(max-width:820px){table.tbl{min-width:560px}}@media(max-width:480px){.admin-body{padding:14px}.kpi-grid{grid-template-columns:1fr}.topbar{flex-wrap:wrap;gap:8px;padding:12px 14px}}.form-error{background:#F9E9E7;color:var(--red);border-radius:11px;padding:11px 13px;font-size:12px;line-height:1.6;margin:6px 0 14px}@media print{.appbar,.no-print{display:none!important}}:focus-visible{outline:3px solid var(--blue);outline-offset:2px;border-radius:6px}.input:focus-visible,.select:focus-visible,.textarea:focus-visible{outline:3px solid var(--blue);outline-offset:1px}.add-row,.btn,.input,.list-row,.select,.step,.toggle-row{min-height:44px}input[type=checkbox],input[type=radio]{min-width:20px;min-height:20px}.badge,.btn{white-space:normal}