:root{--bg-top:#fff7dc;--bg-bottom:#fffdf4;--panel:#fffdf8;--panel-soft:#fff5cf;--line:#ead8a0;--text-main:#3a2d10;--text-sub:#6f5a2b;--accent:#efb21a;--accent-strong:#c98f00;--accent-soft:#fff0b3;--danger:#b53838;--danger-soft:#ffeaea;--shadow:0 16px 44px rgba(121,93,28,0.2);--font-ui:"Avenir Next","Hiragino Sans","Yu Gothic","Noto Sans JP",sans-serif;--font-display:"Avenir Next Condensed","Hiragino Kaku Gothic ProN","Yu Gothic",sans-serif}*{box-sizing:border-box}body,html{margin:0;padding:0;width:100%}body{min-height:100vh;font-family:var(--font-ui);color:var(--text-main);background:linear-gradient(180deg,var(--bg-top) 0,var(--bg-bottom) 100%)}a{color:inherit;text-decoration:none}button,input{font:inherit}.auth-shell{min-height:100vh;display:flex;flex-direction:column;justify-content:space-between;background:radial-gradient(460px 260px at 8% 8%,rgba(242,192,58,.26),transparent 65%),radial-gradient(380px 220px at 95% 12%,rgba(224,151,25,.2),transparent 60%),linear-gradient(180deg,var(--bg-top) 0,var(--bg-bottom) 100%)}.auth-band{height:84px;background:linear-gradient(100deg,#f4c63d,#efb21a 54%,#db8f10)}.auth-band,.auth-main{display:flex;align-items:center;justify-content:center}.auth-main{flex:1 1;padding:24px}.auth-card{width:100%;max-width:980px;background:var(--panel);border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow);padding:42px 36px}.auth-brand{display:flex;align-items:center;gap:12px}.auth-brand-icon{border-radius:20px;box-shadow:0 6px 14px rgba(115,82,16,.2)}.auth-brand-title{margin:0;font-family:var(--font-display);font-size:clamp(28px,3.2vw,40px);line-height:1;letter-spacing:.02em;color:#3a2d10}.brand-sub{margin:0 0 28px;text-align:center;color:var(--text-sub);font-size:16px}.action-wrap{display:flex;justify-content:center}.action-wrap-auth{align-items:center;gap:12px}.button-primary{border:0;border-radius:12px;padding:10px 18px;min-width:148px;font-size:16px;font-weight:700;color:#2f240b;background:linear-gradient(100deg,#f7d358 0,var(--accent) 62%,#e49f12 100%);box-shadow:0 10px 24px rgba(176,128,22,.34);cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,opacity .12s ease}.button-primary:hover{transform:translateY(-1px);box-shadow:0 14px 30px rgba(176,128,22,.42)}.button-primary:disabled{opacity:.56;cursor:not-allowed;transform:none;box-shadow:none}.button-secondary{display:inline-flex;align-items:center;justify-content:center;border:1px solid #d9b45b;border-radius:12px;padding:10px 18px;min-width:148px;font-size:16px;font-weight:700;color:#5a4517;background:#fff8df;box-shadow:0 8px 18px rgba(146,108,27,.18);transition:transform .12s ease,box-shadow .12s ease,background-color .12s ease}.button-secondary:hover{transform:translateY(-1px);box-shadow:0 12px 24px rgba(146,108,27,.26);background:#fff2c9}.auth-footer{height:72px;background:linear-gradient(100deg,#f4c63d,#efb21a 54%,#db8f10)}.signup-form{max-width:460px;margin:10px auto 0;display:grid;grid-gap:16px;gap:16px}.label{display:block;font-size:14px;margin-bottom:8px;color:var(--text-sub)}.input{width:100%;border:1px solid #ddc079;background:#fff;border-radius:10px;padding:12px 14px;color:var(--text-main);outline:none}.input:focus{border-color:#d4a22f;box-shadow:0 0 0 3px rgba(212,162,47,.24)}.error-box{background:var(--danger-soft);border:1px solid #efbcbc;color:var(--danger);border-radius:10px;padding:10px 12px;font-size:14px}.callback-wrap{min-height:100vh;display:grid;place-items:center;padding:24px}.callback-card{width:100%;max-width:520px;border:1px solid var(--line);border-radius:18px;background:var(--panel);box-shadow:var(--shadow);padding:28px 24px;text-align:center}.spinner{width:44px;height:44px;border:4px solid #f1ddb0;border-top:4px solid var(--accent);border-radius:50%;margin:0 auto 14px;animation:spin .82s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.dashboard-shell{min-height:100vh;background:linear-gradient(180deg,rgba(255,248,225,.96),rgba(255,252,242,1));display:grid;grid-template-columns:260px minmax(0,1fr)}.dashboard-sidebar{background:linear-gradient(185deg,#f7d671,#efb724 35%,#e19f16);border-right:1px solid #d6b366;padding:16px 12px;display:grid;align-content:start;grid-gap:14px;gap:14px;position:-webkit-sticky;position:sticky;top:0;height:100vh}.dashboard-brand{background:rgba(255,255,255,.22);border:1px solid rgba(58,45,16,.22);border-radius:12px;padding:12px}.dashboard-brand-title{font-size:20px;font-weight:700;color:#3a2d10}.dashboard-brand-sub{margin-top:2px;font-size:12px;color:rgba(58,45,16,.78)}.dashboard-content{min-width:0}.dashboard-header{min-height:78px;background:rgba(255,247,222,.88);color:#3a2d10;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 20px;border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.dashboard-title{margin:0;font-size:24px;letter-spacing:.01em}.user-meta{text-align:right;font-size:13px;line-height:1.4}.button-ghost{border:1px solid rgba(58,45,16,.35);background:rgba(255,255,255,.4);color:#3a2d10;border-radius:10px;padding:8px 12px;cursor:pointer}.dashboard-main{padding:24px 20px}.dashboard-layout{display:grid;grid-template-columns:240px 1fr;grid-gap:20px;gap:20px;align-items:start}.app-sidebar{border:1px solid var(--line);border-radius:16px;background:var(--panel);box-shadow:0 10px 30px rgba(121,93,28,.14);padding:16px}.app-sidebar-title{margin:0 0 12px;font-size:16px;color:var(--text-sub)}.app-sidebar-nav{display:grid;grid-gap:8px;gap:8px}.app-sidebar-link{display:block;border:1px solid #e2c684;border-radius:10px;background:#fff8df;color:#5a4517;font-weight:700;padding:10px 12px;transition:transform .12s ease,box-shadow .12s ease,background-color .12s ease}.app-sidebar-link:hover{transform:translateY(-1px);box-shadow:0 8px 16px rgba(146,108,27,.2);background:#fff2c9}.app-sidebar-link.is-active{border-color:#d4a22f;background:var(--accent-soft);color:#3a2d10}.panel{border:1px solid var(--line);border-radius:16px;background:var(--panel);box-shadow:0 10px 30px rgba(121,93,28,.14);padding:22px}.panel h2{margin:0 0 10px;font-size:24px}.panel p{margin:0;color:var(--text-sub)}.dashboard-nav{display:grid;grid-gap:8px;gap:8px}.dashboard-nav-link{border:1px solid rgba(116,86,19,.26);border-radius:10px;padding:9px 12px;font-size:14px;font-weight:600;color:#4a3510;background:rgba(255,248,225,.78)}.dashboard-nav-link:hover{background:#fff8df}.dashboard-nav-link-active{color:#fff;background:linear-gradient(130deg,#8d6c18,#6f5211);border-color:rgba(0,0,0,.06)}.panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.panel-head h2{margin:0}.stack{display:grid;grid-gap:12px;gap:12px}.row{display:flex;flex-wrap:wrap;gap:10px}.input-sm{width:auto;min-width:180px}.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:12px;background:#fff}.table{width:100%;border-collapse:collapse;font-size:14px}.table td,.table th{padding:10px 12px;border-bottom:1px solid #f0e3bf;text-align:left;white-space:nowrap}.table th{color:var(--text-sub);background:#fff8df}.table tr:last-child td{border-bottom:0}.muted{color:var(--text-sub);font-size:13px}.danger{color:var(--danger)}.panel-soft{border:1px solid var(--line);border-radius:12px;padding:12px;background:var(--panel-soft)}.notif-wrap{position:relative}.notif-trigger{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(58,45,16,.35);background:rgba(255,255,255,.4);color:#3a2d10;border-radius:12px;padding:8px 10px;cursor:pointer}.notif-trigger-unread{box-shadow:0 0 0 3px rgba(200,143,0,.2)}.notif-badge{min-width:20px;height:20px;border-radius:999px;background:#c32626;color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;padding:0 6px}.notif-pop{position:absolute;right:0;top:calc(100% + 8px);width:min(460px,80vw);max-height:70vh;overflow:auto;border:1px solid var(--line);border-radius:12px;background:#fffdf8;box-shadow:0 14px 30px rgba(121,93,28,.22);padding:10px;z-index:30}.notif-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px}.notif-list{display:grid;grid-gap:8px;gap:8px}.notif-item{border:1px solid #efdcb2;border-radius:10px;padding:10px;background:#fff}.notif-item-unread{border-left:4px solid #d39a0d;background:#fff7df}.notif-meta{display:flex;align-items:center;justify-content:space-between;gap:8px}.notif-title{font-weight:700}.notif-tag{font-size:11px;padding:2px 6px;border-radius:999px;border:1px solid transparent}.notif-tag-info{background:#eef4ff;color:#2f4d86;border-color:#c9daf8}.notif-tag-warning{background:#fff6de;color:#89610e;border-color:#e7cb88}.notif-tag-success{background:#e9f8ef;color:#16623a;border-color:#aad6bd}.notif-tag-error{background:#ffeaea;color:#8d2222;border-color:#f0b4b4}.modal-overlay{position:fixed;inset:0;background:rgba(25,18,7,.44);display:grid;place-items:center;z-index:50;padding:18px}.modal-card{width:min(520px,100%);border:1px solid var(--line);border-radius:14px;background:#fffdf8;box-shadow:var(--shadow);padding:18px;display:grid;grid-gap:12px;gap:12px}@media (max-width:768px){.auth-card{padding:30px 18px;border-radius:18px}.brand-row{flex-direction:column;gap:14px}.button-primary{width:100%}.dashboard-title{font-size:20px}.dashboard-header{padding:14px;flex-direction:column;align-items:flex-start}.user-meta{text-align:left}.dashboard-main{padding:20px 14px}.dashboard-layout{grid-template-columns:1fr}}@media (max-width:1100px){.dashboard-shell{grid-template-columns:1fr}.dashboard-sidebar{position:static;height:auto;border-right:0;border-bottom:1px solid var(--line);background:linear-gradient(180deg,#f5d173,#e8ad1f)}.dashboard-nav{display:flex;gap:8px;overflow-x:auto;padding-bottom:2px}.dashboard-nav-link{white-space:nowrap}}