:root{--bg:#f6f7fb;--card:#fff;--text:#152238;--muted:#728097;--line:#e8edf5;--dark:#0b1220;--gold:#caa45d;--blue:#2854e8;--danger:#d83a3a;--ok:#168a4a;--warn:#b57700;--shadow:0 22px 60px rgba(17,28,45,.10);--radius:24px}*{box-sizing:border-box}body{margin:0;background:linear-gradient(180deg,#f8f9fc,#eef2f8);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif;color:var(--text)}a{color:inherit;text-decoration:none}.wrap{width:min(1180px,calc(100% - 28px));margin:24px auto 60px}.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:20px;padding:18px 28px;background:rgba(255,255,255,.82);backdrop-filter:blur(18px);border-bottom:1px solid var(--line)}.brand{font-weight:900;letter-spacing:-.04em;font-size:24px}.scope{color:var(--muted);font-size:13px;margin-top:2px}.topbar nav{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end}.topbar nav a{padding:10px 13px;border:1px solid transparent;border-radius:999px;color:#33445d;font-weight:700;font-size:13px}.topbar nav a:hover{background:#f4f6fb;border-color:var(--line)}.hero{border-radius:34px;padding:36px;background:radial-gradient(circle at 20% 20%,rgba(202,164,93,.24),transparent 26%),linear-gradient(135deg,#0b1220,#16243b);color:#fff;box-shadow:var(--shadow);position:relative;overflow:hidden}.hero:after{content:"";position:absolute;inset:-60px -80px auto auto;width:280px;height:280px;border-radius:999px;background:rgba(255,255,255,.09)}.hero h1{margin:0;font-size:clamp(32px,5vw,58px);letter-spacing:-.06em;line-height:.96}.hero p{color:rgba(255,255,255,.74);font-size:18px;max-width:760px;line-height:1.6}.grid{display:grid;gap:18px}.grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:0 12px 40px rgba(20,34,55,.06)}.card h2,.card h3{margin:0 0 12px;letter-spacing:-.035em}.muted{color:var(--muted)}.kpi{display:flex;flex-direction:column;gap:8px}.kpi strong{font-size:36px;letter-spacing:-.06em}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:16px;background:var(--dark);color:#fff;padding:13px 17px;font-weight:900;cursor:pointer;box-shadow:0 12px 24px rgba(11,18,32,.14)}.btn.secondary{background:#eef2f7;color:#1c2b43;box-shadow:none}.btn.gold{background:linear-gradient(135deg,#d7b46a,#b98d3b)}.btn.danger{background:var(--danger)}.btn.ok{background:var(--ok)}.btn.small{padding:9px 12px;border-radius:12px;font-size:13px}input,select,textarea{width:100%;border:1px solid var(--line);background:#fff;border-radius:16px;padding:13px 14px;font:inherit;color:var(--text);outline:none}textarea{min-height:96px;resize:vertical}label{display:block;font-size:13px;font-weight:900;color:#44536a;margin:14px 0 7px}.form-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.form-row.three{grid-template-columns:repeat(3,minmax(0,1fr))}.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:18px}table{width:100%;border-collapse:collapse;background:#fff}th,td{text-align:left;padding:13px;border-bottom:1px solid var(--line);vertical-align:top}th{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:#697892;background:#f8fafc}tr:last-child td{border-bottom:0}.badge{display:inline-flex;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:900;background:#eef2f7;color:#43536b}.badge.late{background:#ffe9e9;color:#a41414}.badge.ok{background:#e8f8ef;color:#12683b}.badge.warn{background:#fff4db;color:#855300}.flash{padding:14px 16px;border-radius:16px;margin:0 0 18px;font-weight:800}.flash.ok{background:#e8f8ef;color:#12683b}.flash.err{background:#ffe9e9;color:#a41414}.split{display:flex;justify-content:space-between;gap:16px;align-items:center}.login-shell{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at 20% 10%,rgba(202,164,93,.26),transparent 22%),linear-gradient(135deg,#07101f,#17243c 55%,#0c1424)}.login-card{width:min(480px,calc(100% - 30px));background:rgba(255,255,255,.94);backdrop-filter:blur(22px);border-radius:34px;padding:30px;box-shadow:0 30px 90px rgba(0,0,0,.28)}.login-card h1{font-size:36px;letter-spacing:-.06em;margin:0}.guest-shell{min-height:100vh;background:linear-gradient(180deg,#101a2c,#182941 34%,#f6f7fb 34%)}.guest-top{color:#fff;padding:30px 20px 18px;width:min(980px,100%);margin:0 auto}.guest-top h1{font-size:clamp(34px,6vw,60px);letter-spacing:-.07em;line-height:.94;margin:16px 0 8px}.guest-panel{width:min(980px,calc(100% - 28px));margin:0 auto 60px;background:#fff;border-radius:34px;padding:22px;box-shadow:0 28px 80px rgba(0,0,0,.18)}.guest-menu{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px}.guest-tile{border:1px solid var(--line);border-radius:24px;padding:20px;background:linear-gradient(180deg,#fff,#f8fafc);min-height:150px;display:flex;flex-direction:column;justify-content:space-between}.guest-tile .icon{font-size:32px}.guest-tile strong{font-size:18px;letter-spacing:-.03em}.service-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.service{padding:18px;border:1px solid var(--line);border-radius:20px;background:#fff}.timeline{display:grid;gap:10px}.timeline div{padding:12px 14px;border-left:3px solid var(--gold);background:#fafbfe;border-radius:12px}.module-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.switch{display:flex;justify-content:space-between;align-items:center;padding:12px;border:1px solid var(--line);border-radius:16px;background:#fbfcfe}.switch input{width:auto}.empty{padding:22px;border:1px dashed #cfd7e4;border-radius:20px;color:var(--muted);background:#fbfcfe}.actions{display:flex;gap:8px;flex-wrap:wrap}.request-photo{max-width:240px;border-radius:14px;border:1px solid var(--line)}@media(max-width:900px){.grid.cols-3,.grid.cols-4,.guest-menu{grid-template-columns:repeat(2,minmax(0,1fr))}.topbar{align-items:flex-start;flex-direction:column}.form-row,.form-row.three{grid-template-columns:1fr}.service-list{grid-template-columns:1fr}}@media(max-width:560px){.grid.cols-2,.grid.cols-3,.grid.cols-4,.guest-menu{grid-template-columns:1fr}.guest-panel{border-radius:24px}.card{padding:18px}.hero{padding:26px;border-radius:26px}.topbar nav{justify-content:flex-start}}
