:root{--text:#1f2430;--muted:#5b6473;--bg:#f7f9fc;--surface:#fff;--border:#e3e8ef;--accent:#2f6fed;--accent-d:#1f54c0;--danger:#c0392b;--radius:10px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--accent-soft:#eaf1fe;--accent-soft-h:#f2f6ff;--surface-2:#f1f4f9;--hover:#f3f5f9;--shadow:0 1px 2px #141e370f, 0 6px 16px #141e370f;--shadow-sm:0 1px 2px #141e370f;--radius-sm:8px;--radius-lg:14px;--sidebar-w:256px;--topbar-h:60px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:24px;--space-6:32px;font:16px/1.5 var(--sans);color:var(--text);background:var(--bg)}*{box-sizing:border-box}body{margin:0}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.skip-link{z-index:1000;background:var(--accent);color:#fff;border-radius:var(--radius);padding:8px 14px;transition:top .15s;position:absolute;top:-48px;left:8px}.skip-link:focus{text-decoration:none;top:8px}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}}.layout{flex-direction:column;min-height:100svh;display:flex}.topbar{background:var(--surface);border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:12px 24px;display:flex}.brand{color:var(--text);letter-spacing:-.01em;align-items:center;gap:10px;font-size:1.1rem;font-weight:700;display:inline-flex}.brand:hover{text-decoration:none}.nav{flex-wrap:wrap;align-items:center;gap:10px;margin:0;padding:0;list-style:none;display:flex}.nav li{align-items:center;display:inline-flex}.container{width:100%;max-width:1080px;margin:0 auto;padding:24px}.nav-link{border-radius:var(--radius-sm);color:var(--muted);align-items:center;padding:7px 12px;font-weight:500;transition:background-color .12s,color .12s;display:inline-flex}.nav-link:hover{background:var(--hover);color:var(--text);text-decoration:none}.nav-link.is-active{background:var(--accent-soft);color:var(--accent-d);font-weight:600}.btn{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;font:inherit;align-items:center;gap:6px;padding:8px 14px;font-weight:500;transition:background-color .12s,border-color .12s;display:inline-flex}.btn:hover{border-color:var(--accent);background:var(--accent-soft-h);text-decoration:none}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-d);border-color:var(--accent-d);color:#fff}.btn-link{color:var(--accent);cursor:pointer;font:inherit;background:0 0;border:none;padding:0}.lang-switch{border:1px solid var(--border);border-radius:var(--radius);display:inline-flex;overflow:hidden}.lang-switch button{background:var(--surface);cursor:pointer;font:inherit;color:var(--muted);border:none;padding:6px 10px}.lang-switch button[aria-pressed=true]{background:var(--accent);color:#fff}.hero{text-align:center;padding:48px 16px}.hero h1{margin:0 0 12px;font-size:2rem}.hero p{color:var(--muted);margin:0 0 20px}.card-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;display:grid}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--text);padding:20px;font-weight:600;transition:border-color .12s,box-shadow .12s,transform .12s;display:block}.card:hover{border-color:var(--accent);box-shadow:var(--shadow);text-decoration:none}.form-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:14px;max-width:380px;margin:40px auto;padding:28px;display:flex}.form-card h1{margin:0 0 4px;font-size:1.4rem}label{color:var(--muted);flex-direction:column;gap:4px;font-size:.9rem;display:flex}input,select,textarea{border:1px solid var(--border);font:inherit;color:var(--text);background:#fff;border-radius:8px;padding:9px 11px}input:focus,select:focus,textarea:focus{outline:2px solid var(--accent);border-color:var(--accent)}.error{color:var(--danger)}.muted{color:var(--muted)}.table-scroll{-webkit-overflow-scrolling:touch;width:100%;overflow-x:auto}@media (width<=600px){.btn,.btn-link,.nav a,.nav-link,.lang-switch button{min-height:40px}.container{padding:16px}}.shell-brand-mark{border-radius:var(--radius-sm);background:var(--accent);color:#fff;letter-spacing:-.02em;flex:none;justify-content:center;align-items:center;width:30px;height:30px;font-size:.85rem;font-weight:700;display:inline-flex}.topbar--public{box-shadow:var(--shadow-sm);padding:12px 28px}.shell{grid-template-columns:var(--sidebar-w) 1fr;background:var(--bg);grid-template-areas:"sidebar main";min-height:100svh;display:grid}.shell-sidebar{background:var(--surface);border-right:1px solid var(--border);z-index:30;flex-direction:column;grid-area:sidebar;height:100svh;display:flex;position:sticky;top:0}.shell-brand-block{justify-content:space-between;align-items:center;gap:var(--space-2);height:var(--topbar-h);padding:0 var(--space-4);border-bottom:1px solid var(--border);flex:none;display:flex}.shell-brand{color:var(--text);letter-spacing:-.01em;align-items:center;gap:10px;min-width:0;font-size:1.02rem;font-weight:700;display:inline-flex}.shell-brand:hover{text-decoration:none}.shell-brand-text{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.shell-sidebar-scroll{padding:var(--space-4) var(--space-3);flex:auto;overflow-y:auto}.shell-nav{gap:var(--space-5);flex-direction:column;min-height:100%;display:flex}.shell-nav-group{gap:var(--space-1);flex-direction:column;display:flex}.shell-nav-heading{margin:0 0 var(--space-1);padding:0 var(--space-3);letter-spacing:.06em;text-transform:uppercase;color:var(--muted);font-size:.7rem;font-weight:700}.shell-nav-list{flex-direction:column;gap:2px;margin:0;padding:0;list-style:none;display:flex}.shell-nav-link{border-radius:var(--radius-sm);color:var(--muted);font-weight:500;transition:background-color .12s,color .12s;display:block;position:relative}.shell-nav-link-inner{padding:9px var(--space-3);align-items:center;gap:10px;display:flex}.shell-nav-icon{flex:none;width:20px;height:20px}.shell-nav-label{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.shell-nav-link:hover{background:var(--hover);color:var(--text);text-decoration:none}.shell-nav-link.is-active{background:var(--accent-soft);color:var(--accent-d);font-weight:600}.shell-nav-link.is-active:before{content:"";background:var(--accent);border-radius:0 3px 3px 0;width:3px;position:absolute;top:6px;bottom:6px;left:0}.shell-nav-foot{padding-top:var(--space-4);margin-top:auto}.shell-switch{padding:9px var(--space-3);border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-2);color:var(--text);align-items:center;gap:10px;font-size:.92rem;font-weight:600;transition:border-color .12s,background-color .12s;display:flex}.shell-switch span{flex:auto}.shell-switch:hover{border-color:var(--accent);background:var(--accent-soft-h);text-decoration:none}.shell-drawer-close{width:40px;height:40px;color:var(--muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;justify-content:center;align-items:center;display:none}.shell-drawer-close:hover{background:var(--hover);color:var(--text)}.shell-main-col{flex-direction:column;grid-area:main;min-width:0;min-height:100svh;display:flex}.shell-topbar{align-items:center;gap:var(--space-3);height:var(--topbar-h);padding:0 var(--space-5);background:var(--surface);border-bottom:1px solid var(--border);z-index:20;flex:none;display:flex;position:sticky;top:0}.shell-topbar-spacer{flex:auto}.shell-hamburger{border:1px solid var(--border);background:var(--surface);width:40px;height:40px;color:var(--text);cursor:pointer;border-radius:var(--radius-sm);justify-content:center;align-items:center;display:none}.shell-hamburger:hover{border-color:var(--accent);background:var(--accent-soft-h)}.shell-content{flex:auto;min-width:0}.shell-account{position:relative}.shell-avatar{border:1px solid var(--border);background:var(--accent-soft);width:38px;height:38px;color:var(--accent-d);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-size:.82rem;font-weight:700;transition:border-color .12s;display:inline-flex}.shell-avatar:hover{border-color:var(--accent)}.shell-account-menu{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);min-width:220px;max-width:280px;box-shadow:var(--shadow);padding:var(--space-2);z-index:40;position:absolute;top:calc(100% + 8px);right:0}.shell-account-head{padding:var(--space-2) var(--space-3) var(--space-3);border-bottom:1px solid var(--border);margin-bottom:var(--space-2)}.shell-account-name{overflow-wrap:anywhere;margin:0;font-weight:600}.shell-account-email{color:var(--muted);overflow-wrap:anywhere;margin:2px 0 0;font-size:.85rem}.shell-account-action{width:100%;padding:9px var(--space-3);cursor:pointer;font:inherit;color:var(--text);border-radius:var(--radius-sm);text-align:left;background:0 0;border:none;align-items:center;gap:10px;display:flex}.shell-account-action:hover{background:var(--hover)}.shell-overlay{z-index:25;cursor:pointer;background:#141e3766;border:none;margin:0;padding:0;display:none;position:fixed;inset:0}@media (width<=900px){.shell{grid-template-columns:1fr;grid-template-areas:"main"}.shell-sidebar{width:min(82vw, var(--sidebar-w));box-shadow:var(--shadow);z-index:35;transition:transform .18s;position:fixed;top:0;left:0;transform:translate(-100%)}.shell--drawer-open .shell-sidebar{transform:translate(0)}.shell--drawer-open .shell-overlay{display:block}.shell-hamburger,.shell-drawer-close{display:inline-flex}}@media (width<=600px){.shell-nav-link-inner,.shell-switch,.shell-account-action{min-height:40px}.shell-content>.container{padding:16px}}
