:root{--brand:#002f6c;--brand-mid:#1453a5;--brand-2:#0079c2;--brand-tint:#e5eff9;--brand-tint-border:#b8d0ea;--bg:#f0f4fc;--bg-2:#e8eff9;--surface:#fff;--surface-2:#f4f7fd;--surface-glass:hsla(0,0%,100%,.88);--ink:#0d1b2a;--muted:#5a6478;--ink-soft:#334155;--line:#c5d0e6;--danger:#c0392b;--danger-dark:#7f1d1d;--ok:#1a7d4f;--shadow:0 12px 28px rgba(0,47,108,.09);--shadow-sm:0 2px 8px rgba(0,47,108,.06);--shadow-lg:0 20px 40px rgba(0,47,108,.15);--radius:14px;--transition:0.15s ease}@media (prefers-color-scheme:dark){:root:not([data-theme=light]){--brand:#1453a5;--brand-mid:#1a72c7;--brand-2:#1e8ae0;--brand-tint:#1a2535;--brand-tint-border:#2d3f55;--bg:#111214;--bg-2:#18191c;--surface:#1e2025;--surface-2:#25272d;--surface-glass:rgba(17,18,20,.9);--ink:#e8e9ec;--muted:#8b8f9a;--ink-soft:#6b7280;--line:#2d2f36;--danger:#ff6b6b;--danger-dark:#c0392b;--ok:#4ade80;--shadow:0 12px 28px rgba(0,0,0,.55);--shadow-sm:0 2px 8px rgba(0,0,0,.4);--shadow-lg:0 20px 40px rgba(0,0,0,.65)}}[data-theme=dark]{--brand:#1453a5;--brand-mid:#1a72c7;--brand-2:#1e8ae0;--brand-tint:#1a2535;--brand-tint-border:#2d3f55;--bg:#111214;--bg-2:#18191c;--surface:#1e2025;--surface-2:#25272d;--surface-glass:rgba(17,18,20,.9);--ink:#e8e9ec;--muted:#8b8f9a;--ink-soft:#6b7280;--line:#2d2f36;--danger:#ff6b6b;--danger-dark:#c0392b;--ok:#4ade80;--shadow:0 12px 28px rgba(0,0,0,.55);--shadow-sm:0 2px 8px rgba(0,0,0,.4);--shadow-lg:0 20px 40px rgba(0,0,0,.65)}[data-theme=light]{--brand:#002f6c;--brand-mid:#1453a5;--brand-2:#0079c2;--brand-tint:#e5eff9;--brand-tint-border:#b8d0ea;--bg:#f0f4fc;--bg-2:#e8eff9;--surface:#fff;--surface-2:#f4f7fd;--surface-glass:hsla(0,0%,100%,.88);--ink:#0d1b2a;--muted:#5a6478;--ink-soft:#334155;--line:#c5d0e6;--danger:#c0392b;--danger-dark:#7f1d1d;--ok:#1a7d4f;--shadow:0 12px 28px rgba(0,47,108,.09);--shadow-sm:0 2px 8px rgba(0,47,108,.06);--shadow-lg:0 20px 40px rgba(0,47,108,.15)}*{box-sizing:border-box}body,html{margin:0;min-height:100%}body{color:var(--ink);font-family:Inter,Segoe UI,Helvetica Neue,sans-serif;font-feature-settings:"cv02","cv03","cv04","cv11";background:radial-gradient(1000px 500px at 0 0,#c8ddef 0,transparent 60%),radial-gradient(1200px 550px at 100% 100%,#bdd6f0 0,transparent 60%),linear-gradient(180deg,var(--bg-2),var(--bg));transition:background-color var(--transition),color var(--transition)}[data-theme=dark] body{background:radial-gradient(900px 400px at 0 0,#021e4a 0,transparent 55%),radial-gradient(1000px 450px at 100% 100%,#012040 0,transparent 55%),linear-gradient(180deg,var(--bg-2),var(--bg))}@media (prefers-color-scheme:dark){:root:not([data-theme=light]) body{background:radial-gradient(900px 400px at 0 0,#021e4a 0,transparent 55%),radial-gradient(1000px 450px at 100% 100%,#012040 0,transparent 55%),linear-gradient(180deg,var(--bg-2),var(--bg))}}a{color:var(--brand-2);text-decoration:none}a:hover{text-decoration:underline}.site-shell{max-width:1140px;margin:0 auto;padding:24px}.muted{color:var(--muted)}.site-header{background:var(--surface-glass);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);margin-bottom:18px;padding:14px 18px}.site-header-row{justify-content:space-between;gap:14px;flex-wrap:wrap}.brand,.site-header-row{display:flex;align-items:center}.brand{gap:10px}.brand-link{color:inherit}.brand-link,.brand-link:hover{text-decoration:none}.brand-chip{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;display:grid;place-items:center;font-size:13px;font-weight:700;letter-spacing:.04em;flex-shrink:0}.brand-title{margin:0;font-size:1.05rem;letter-spacing:.01em;font-weight:600;color:var(--ink)}.nav-links{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.nav-links a{display:inline-block;padding:8px 14px;border-radius:999px;border:1px solid transparent;font-size:.9rem;font-weight:500;color:var(--ink);transition:background var(--transition),border-color var(--transition)}.nav-links a.active,.nav-links a:hover{border-color:var(--brand-tint-border);background:var(--brand-tint);color:var(--brand)}.nav-links a:hover{text-decoration:none}.nav-btn{border:1px solid var(--line);border-radius:999px;background:var(--surface);color:var(--ink-soft);font-size:.9rem;font-weight:600;padding:8px 14px;transition:background var(--transition),box-shadow var(--transition)}.nav-btn:hover{background:var(--surface-2);box-shadow:var(--shadow-sm);transform:none;filter:none}@media (prefers-color-scheme:dark){:root:not([data-theme=light]) .nav-btn{color:var(--ink);border-color:#3a3c45}}[data-theme=dark] .nav-btn{color:var(--ink);border-color:#3a3c45}.theme-toggle{border:1px solid var(--line);border-radius:999px;background:var(--surface);color:var(--muted);font-size:.88rem;font-weight:600;padding:7px 12px;cursor:pointer;display:inline-flex;align-items:center;gap:5px;transition:background var(--transition),color var(--transition),border-color var(--transition)}.theme-toggle:hover{background:var(--brand-tint);border-color:var(--brand-tint-border);color:var(--brand);transform:none;box-shadow:none;filter:none}.switch-btn{position:relative;width:48px;height:28px;border-radius:999px;border:1px solid var(--line);background:var(--surface-2);display:inline-flex;align-items:center;padding:2px;cursor:pointer;transition:background var(--transition),border-color var(--transition)}.switch-btn .switch-knob{width:22px;height:22px;border-radius:999px;background:var(--surface);box-shadow:0 1px 4px rgba(0,0,0,.25);transform:translateX(0);transition:transform var(--transition)}.switch-btn.on{background:var(--brand);border-color:var(--brand)}.switch-btn.on .switch-knob{transform:translateX(20px)}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px}.card-soft{background:var(--surface-2);border:1px solid var(--line);border-radius:12px;padding:14px}.row{display:flex;gap:12px;flex-wrap:wrap}.grid-2{display:grid;grid-template-columns:1.2fr 1fr;grid-gap:18px;gap:18px}.auth-wrap{max-width:480px;margin:34px auto 0}.auth-brand{display:flex;align-items:center;gap:10px;margin-bottom:24px}.auth-brand-chip{width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;display:grid;place-items:center;font-size:13px;font-weight:700;letter-spacing:.04em;flex-shrink:0}.auth-brand-name{font-size:1rem;font-weight:600;color:var(--ink);letter-spacing:.01em}.auth-title{margin:0 0 4px;font-size:1.7rem;font-weight:700;letter-spacing:-.02em;color:var(--ink)}.auth-subtitle{margin:0 0 20px;color:var(--muted);font-size:.95rem}.auth-footer{margin-top:20px;text-align:center;font-size:.9rem;color:var(--muted)}button,input,select,textarea{font:inherit;border-radius:10px;border:1px solid var(--line);padding:10px 12px}input,select,textarea{width:100%;background:var(--surface);color:var(--ink);transition:border-color var(--transition),box-shadow var(--transition)}input::placeholder,textarea::placeholder{color:var(--muted);opacity:.7}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brand-2);box-shadow:0 0 0 3px rgba(0,121,194,.25)}[data-theme=dark] input:focus,[data-theme=dark] select:focus,[data-theme=dark] textarea:focus{box-shadow:0 0 0 3px rgba(76,184,255,.25)}button{border:none;background:linear-gradient(135deg,var(--brand),var(--brand-mid));color:#fff;font-weight:600;cursor:pointer;transition:transform var(--transition),box-shadow var(--transition),filter var(--transition)}button:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,47,108,.35);filter:brightness(1.06)}[data-theme=dark] button:hover{box-shadow:0 4px 12px rgba(76,184,255,.3)}button:active{transform:translateY(0)}button:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}a.secondary,button.secondary{background:var(--surface-2);color:var(--ink);border:1.5px solid var(--line);border-radius:10px;font:inherit;font-weight:600;cursor:pointer;transition:background var(--transition),border-color var(--transition),color var(--transition),box-shadow var(--transition),transform var(--transition)}a.secondary:hover,button.secondary:hover{background:var(--brand-tint);border-color:var(--brand-tint-border);color:var(--brand);box-shadow:var(--shadow-sm);transform:translateY(-1px)}a.secondary:active{transform:translateY(0)}button.danger{background:linear-gradient(135deg,var(--danger),var(--danger-dark))}button.danger:hover{box-shadow:0 4px 12px rgba(192,57,43,.35)}.btn-photo-upload{display:inline-flex;align-items:center;background:linear-gradient(135deg,var(--brand),var(--brand-mid));color:#fff;border-radius:10px;padding:10px 12px;font-weight:600;cursor:pointer;transition:transform var(--transition),box-shadow var(--transition),filter var(--transition)}.btn-photo-upload:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,47,108,.35);filter:brightness(1.06)}.btn-photo-upload.disabled{opacity:.65;cursor:not-allowed;transform:none;box-shadow:none;filter:none}button.btn-photo-danger{background:linear-gradient(135deg,var(--danger),var(--danger-dark));color:#fff;border:none;border-radius:10px;padding:10px 12px;font-weight:600;cursor:pointer;transition:transform var(--transition),box-shadow var(--transition),filter var(--transition)}button.btn-photo-danger:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px rgba(192,57,43,.35);filter:brightness(1.06)}button.btn-photo-danger:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none;filter:none}label{display:block;font-size:.875rem;font-weight:500;color:var(--muted);margin-bottom:6px}.field{margin-bottom:14px}.error{color:var(--danger)}.error,.ok{font-size:.92rem}.ok{color:var(--ok)}.pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;font-size:.78rem;background:var(--surface)}.badge,.pill{border-radius:999px;border:1px solid var(--line);color:var(--muted)}.badge{display:inline-block;padding:4px 9px;font-size:.75rem;font-weight:500;background:var(--surface-2)}.badge.admin{color:var(--brand);background:var(--brand-tint);border-color:var(--brand-tint-border)}.badge.active,.badge.employee{color:var(--ok);background:color-mix(in srgb,var(--ok) 12%,var(--surface));border-color:color-mix(in srgb,var(--ok) 35%,var(--surface))}.badge.inactive{color:#92400e;background:#fef3c7;border-color:#fcd34d}[data-theme=dark] .badge.inactive{color:#fcd34d;background:rgba(252,211,77,.12);border-color:rgba(252,211,77,.3)}.data-table{width:100%;border-collapse:collapse}.data-table td,.data-table th{padding:10px 8px;border-bottom:1px solid var(--line);text-align:left;vertical-align:middle;color:var(--ink)}.data-table th{font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}.kv{margin:0;display:grid;grid-template-columns:120px 1fr;grid-gap:8px;gap:8px;font-size:.94rem}.kv dt{color:var(--muted)}.kv dd{margin:0;color:var(--ink)}.hero-section{text-align:center;padding:56px 24px 48px}.hero-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:999px;font-size:.8rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--brand);background:var(--brand-tint);border:1px solid var(--brand-tint-border);margin-bottom:20px}.hero-title{margin:0 0 16px;font-size:clamp(2rem,5vw,3rem);font-weight:700;letter-spacing:-.03em;line-height:1.15;background:linear-gradient(135deg,var(--brand) 0,var(--brand-2) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-sub{color:var(--muted);font-size:1.1rem;max-width:520px;margin:0 auto 32px;line-height:1.6}.hero-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.hero-cta .btn-primary{display:inline-flex;align-items:center;gap:8px;padding:13px 28px;border-radius:12px;background:linear-gradient(135deg,var(--brand),var(--brand-mid));color:#fff;font-weight:600;font-size:1rem;text-decoration:none;border:none;cursor:pointer;transition:transform var(--transition),box-shadow var(--transition);box-shadow:0 4px 14px rgba(0,47,108,.35)}.hero-cta .btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,47,108,.4);text-decoration:none;filter:brightness(1.06)}@media (prefers-color-scheme:dark){:root:not([data-theme=light]) .hero-cta .btn-primary{box-shadow:0 4px 14px rgba(0,47,108,.35)}}[data-theme=dark] .hero-cta .btn-primary{box-shadow:0 4px 14px rgba(0,47,108,.35)}[data-theme=dark] .hero-cta .btn-primary:hover{box-shadow:0 8px 20px rgba(0,47,108,.45)}.hero-cta .btn-outline{display:inline-flex;align-items:center;gap:8px;padding:13px 28px;border-radius:12px;background:var(--surface);color:var(--brand);font-weight:600;font-size:1rem;text-decoration:none;border:1.5px solid var(--brand-tint-border);cursor:pointer;transition:transform var(--transition),box-shadow var(--transition),background var(--transition)}.hero-cta .btn-outline:hover{transform:translateY(-2px);background:var(--brand-tint);box-shadow:var(--shadow-sm);text-decoration:none}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:16px;gap:16px;margin-top:16px}.feature-tile{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:24px;text-align:left;transition:transform var(--transition),box-shadow var(--transition)}.feature-tile:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}.feature-icon{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,var(--brand),var(--brand-2));display:grid;place-items:center;margin-bottom:14px}.feature-tile h3{margin:0 0 6px;font-size:1rem;font-weight:600;color:var(--ink)}.feature-tile p{margin:0;color:var(--muted);font-size:.9rem;line-height:1.55}.hero-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:12px;gap:12px}.hero-tile{border:1px solid var(--line);border-radius:12px;padding:14px;background:var(--surface);transition:transform var(--transition),box-shadow var(--transition)}.hero-tile:hover{transform:translateY(-2px);box-shadow:var(--shadow);text-decoration:none}.hero-tile h3{margin:0 0 4px;font-size:1.02rem;color:var(--ink)}.hero-tile p{margin:0;color:var(--muted);font-size:.9rem}.public-page{min-height:80vh;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:20px 16px 40px}.public-card-wrap{width:100%;max-width:440px}.public-card-header-logo{max-height:72px;max-width:calc(100% - 48px);width:auto;display:block;object-fit:contain}.public-card{background:var(--surface);border-radius:20px;box-shadow:var(--shadow-lg);overflow:hidden;border:1px solid var(--line)}.public-card-header{height:120px;background:linear-gradient(135deg,#002f6c,#0079c2);align-items:flex-start;padding-top:16px}.public-card-avatar-wrap,.public-card-header{position:relative;display:flex;justify-content:center}.public-card-avatar-wrap{z-index:1}.public-card-avatar{width:96px;height:96px;border-radius:50%;border:4px solid var(--surface);margin-top:-48px;background:var(--surface);overflow:hidden;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px rgba(0,0,0,.18);flex-shrink:0}.public-card-avatar img{width:100%;height:100%;object-fit:cover}.public-card-avatar-initials{width:100%;height:100%;background:linear-gradient(135deg,var(--brand),var(--brand-2));display:flex;align-items:center;justify-content:center;font-size:1.6rem;font-weight:700;color:#fff;letter-spacing:.04em}.public-card-body{padding:12px 28px 28px;text-align:center}.public-card-name{margin:12px 0 4px;font-size:1.45rem;font-weight:700;letter-spacing:-.02em;color:var(--ink)}.public-card-position{margin:0 0 6px;font-size:.95rem;color:var(--brand-2);font-weight:500}.public-card-dept{margin:0 0 20px;font-size:.875rem;color:var(--muted)}.public-card-divider{height:1px;background:var(--line);margin:0 0 20px}.contact-list{display:flex;flex-direction:column;gap:10px;text-align:left;margin-bottom:20px}.contact-item{gap:12px;font-size:.9rem;color:var(--ink)}.contact-icon,.contact-item{display:flex;align-items:center}.contact-icon{width:34px;height:34px;border-radius:8px;background:var(--brand-tint);justify-content:center;flex-shrink:0;color:var(--brand)}.contact-item a{color:var(--brand-2);word-break:break-all}.lang-tabs{display:flex;gap:6px;justify-content:center;margin-bottom:4px}.lang-tab{padding:5px 16px;border-radius:999px;border:1.5px solid var(--line);background:var(--surface-2);color:var(--muted);font-size:.82rem;font-weight:600;cursor:pointer;letter-spacing:.04em;transition:background var(--transition),border-color var(--transition),color var(--transition)}.lang-tab:hover{border-color:var(--brand-tint-border);background:var(--brand-tint);color:var(--brand);transform:none;box-shadow:none}.lang-tab.active{background:linear-gradient(135deg,var(--brand),var(--brand-mid));border-color:transparent;color:#fff;box-shadow:0 2px 8px rgba(0,47,108,.3)}[data-theme=dark] .lang-tab.active{box-shadow:0 2px 8px rgba(0,47,108,.35)}.lang-tab.active:hover{color:#fff}.export-bar{margin-top:16px;display:flex;flex-wrap:wrap;gap:10px;width:100%}.export-btn{flex-grow:1;flex-shrink:1;flex-basis:calc(33.333% - 7px);display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 16px;border-radius:12px;background:var(--surface);color:var(--ink-soft);border:1.5px solid var(--line);font-size:.88rem;font-weight:600;cursor:pointer;transition:background var(--transition),border-color var(--transition),transform var(--transition),box-shadow var(--transition)}.export-btn:hover{background:var(--brand-tint);border-color:var(--brand-tint-border);color:var(--brand);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.export-btn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}@media (prefers-color-scheme:dark){:root:not([data-theme=light]) .export-btn{color:var(--ink);border-color:#3a3c45;background:#25272d}}[data-theme=dark] .export-btn{color:var(--ink);border-color:#3a3c45;background:#25272d}[data-theme=dark] .export-btn:hover{background:var(--brand-tint);border-color:var(--brand-tint-border);color:var(--brand)}@media (max-width:920px){.features-grid,.grid-2{grid-template-columns:1fr}}@media (max-width:640px){.site-shell{padding:14px}.features-grid,.hero-grid{grid-template-columns:1fr}.hero-section{padding:36px 8px 32px}.public-page{padding:12px 12px 32px}}