/* Софія — преміальний кабінет-кокпіт забудовника Мартинова.
   Темна «еспресо» база + золото + вершкові акценти. Дорого, спокійно, владно. */
:root{
  --bg:#15110b; --bg2:#1b150d;
  --panel:#221b11; --panel2:#2a2115; --panel3:#332817;
  --line:rgba(224,179,74,.16); --line-soft:rgba(224,179,74,.09);
  --gold:#e0b34a; --gold-2:#f3d27e; --gold-deep:#c5860d; --gold-dim:#9a7d3e;
  --cream:#f4ecd9; --ink:#efe6d2; --ink-soft:#b6a585; --ink-dim:#897a5f;
  --pos:#6fbf73; --neg:#e0795f; --warn:#e8b84e; --info:#7ab7c9;
  --shadow:0 24px 60px rgba(0,0,0,.45);
  --r:18px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
::selection{background:rgba(224,179,74,.3);color:#fff}
:focus-visible{outline:2px solid var(--gold);outline-offset:2px;border-radius:6px}
body{
  font-family:'Manrope',system-ui,-apple-system,Segoe UI,sans-serif;
  color:var(--ink);
  background:
    radial-gradient(1200px 600px at 78% -8%, rgba(224,179,74,.10), rgba(224,179,74,0) 55%),
    radial-gradient(900px 500px at 8% 110%, rgba(197,134,13,.08), rgba(197,134,13,0) 55%),
    linear-gradient(180deg,var(--bg) 0%, var(--bg2) 100%);
  background-attachment:fixed;
  min-height:100vh; -webkit-font-smoothing:antialiased;
}
.serif{font-family:'Prata',Georgia,serif;font-weight:400}
.hidden{display:none !important}

/* Лейаут: бічна навігація + контент */
.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh;max-width:1320px;margin:0 auto}
@media(max-width:860px){.app{grid-template-columns:1fr}}

/* Бічна панель */
.side{border-right:1px solid var(--line-soft);padding:24px 18px;display:flex;flex-direction:column;gap:6px;position:sticky;top:0;height:100vh}
@media(max-width:860px){.side{position:static;height:auto;border-right:none;border-bottom:1px solid var(--line-soft);flex-direction:row;flex-wrap:wrap;align-items:center;gap:8px;padding:14px}}
.brand{display:flex;align-items:center;gap:12px;margin-bottom:20px;padding:0 6px}
@media(max-width:860px){.brand{margin-bottom:0;flex:1}}
.brand .mark{width:46px;height:46px;border-radius:50%;flex:none;display:grid;place-items:center;
  background:radial-gradient(circle at 38% 30%, #fff2cf, #e0b34a 52%, #b07d1e);
  box-shadow:0 6px 20px rgba(224,179,74,.35), inset 0 -3px 8px rgba(120,80,0,.4)}
.brand .mark span{font-family:'Prata',serif;font-size:24px;color:#3a2a08;line-height:1;margin-top:2px}
.brand b{font-family:'Prata',serif;font-size:22px;font-weight:400;letter-spacing:.3px;display:block;line-height:1}
.brand small{display:block;color:var(--ink-dim);font-size:11px;letter-spacing:.6px;text-transform:uppercase;margin-top:3px}

.nav{display:flex;flex-direction:column;gap:4px}
@media(max-width:860px){.nav{flex-direction:row;flex-wrap:wrap;width:100%}}
.nav button{display:flex;align-items:center;gap:11px;border:none;background:transparent;color:var(--ink-soft);
  padding:12px 14px;border-radius:12px;font:inherit;font-weight:600;font-size:14.5px;cursor:pointer;text-align:left;transition:.15s}
.nav button .ic{font-size:17px;width:20px;text-align:center}
.nav button:hover{background:var(--panel);color:var(--ink)}
.nav button.active{background:linear-gradient(135deg,rgba(224,179,74,.18),rgba(224,179,74,.06));color:var(--gold-2);box-shadow:inset 0 0 0 1px var(--line)}
.side-foot{margin-top:auto;padding:12px 8px 0;font-size:11px;color:var(--ink-dim)}
@media(max-width:860px){.side-foot{display:none}}

/* Контент */
.main{padding:30px 34px 60px;min-width:0}
@media(max-width:860px){.main{padding:20px 16px 50px}}
.view{animation:fade .3s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:22px;flex-wrap:wrap}
.page-head h1{font-family:'Prata',serif;font-weight:400;font-size:30px;margin:0;letter-spacing:.3px}
.page-head .sub{color:var(--ink-soft);font-size:14px;margin-top:4px}

/* Картки/панелі */
.panel{background:linear-gradient(180deg,var(--panel),var(--panel2));border:1px solid var(--line-soft);border-radius:var(--r);box-shadow:var(--shadow);padding:20px}
.panel.glow{box-shadow:var(--shadow), 0 0 0 1px var(--line), 0 0 40px rgba(224,179,74,.06)}
.grid{display:grid;gap:16px}
.cols-2{grid-template-columns:1fr 1fr}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:860px){.cols-2,.cols-3,.cols-4{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.cols-2,.cols-3,.cols-4{grid-template-columns:1fr}}

/* KPI-плитки */
.kpi{background:linear-gradient(180deg,var(--panel),var(--panel2));border:1px solid var(--line-soft);border-radius:16px;padding:16px 18px;position:relative;overflow:hidden}
.kpi::after{content:'';position:absolute;right:-30px;top:-30px;width:90px;height:90px;border-radius:50%;background:radial-gradient(circle,rgba(224,179,74,.12),transparent 70%)}
.kpi .lab{font-size:12px;color:var(--ink-soft);letter-spacing:.3px}
.kpi .val{font-family:'Prata',serif;font-size:30px;margin:6px 0 2px;line-height:1}
.kpi .delta{font-size:12.5px;font-weight:700}
.kpi .delta.up{color:var(--pos)} .kpi .delta.down{color:var(--neg)}

/* Інсайт Софії */
.insight{display:flex;gap:16px;align-items:flex-start;background:
  linear-gradient(135deg,rgba(224,179,74,.12),rgba(224,179,74,.03));border:1px solid var(--line);border-radius:var(--r);padding:18px 20px}
.insight .ava{width:48px;height:48px;border-radius:50%;flex:none;background:radial-gradient(circle at 38% 30%, #fff2cf, #e0b34a 52%, #b07d1e);display:grid;place-items:center;font-family:'Prata',serif;color:#3a2a08;font-size:22px;box-shadow:0 4px 14px rgba(224,179,74,.3)}
.insight .body b{color:var(--gold-2);font-weight:700}
.insight .body .who{font-family:'Prata',serif;color:var(--gold-2);font-size:15px;margin-bottom:3px}
.insight .body p{margin:0;font-size:14.5px;line-height:1.55;color:var(--ink)}

/* Земельний скаут */
.filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.filters button,.chip{background:var(--panel);border:1px solid var(--line-soft);color:var(--ink-soft);padding:8px 13px;border-radius:999px;font:inherit;font-size:13px;font-weight:600;cursor:pointer}
.filters button.active{background:linear-gradient(135deg,rgba(224,179,74,.2),rgba(224,179,74,.06));color:var(--gold-2);border-color:var(--line)}
.land{display:flex;flex-direction:column;gap:13px}
.lot{display:grid;grid-template-columns:64px 1fr auto;gap:16px;align-items:center;background:linear-gradient(180deg,var(--panel),var(--panel2));border:1px solid var(--line-soft);border-radius:16px;padding:16px 18px;transition:.15s}
.lot:hover{border-color:var(--line);transform:translateY(-1px)}
.lot.top{box-shadow:0 0 0 1px var(--line),0 0 30px rgba(224,179,74,.08)}
.ring{width:60px;height:60px;border-radius:50%;display:grid;place-items:center;font-weight:800;font-size:17px;color:var(--cream);position:relative}
.ring small{position:absolute;bottom:8px;font-size:8px;color:var(--ink-dim);font-weight:600}
.lot .t{font-size:16.5px;font-weight:700;color:var(--ink)}
.lot .m{font-size:13px;color:var(--ink-soft);margin-top:3px;display:flex;gap:12px;flex-wrap:wrap}
.lot .m .tag{background:var(--panel3);border-radius:6px;padding:2px 8px;font-size:11.5px;color:var(--gold-2);font-weight:600}
.lot .price{text-align:right;white-space:nowrap}
.lot .price b{font-family:'Prata',serif;font-size:20px;color:var(--gold-2);display:block}
.lot .price small{color:var(--ink-soft);font-size:12px}
.lot .note{grid-column:1/-1;font-size:13px;color:var(--ink-soft);border-top:1px dashed var(--line-soft);margin-top:6px;padding-top:9px;line-height:1.5}
.lot .note b{color:var(--gold-2)}

/* Портфель ЖК */
.zk{display:grid;grid-template-columns:1fr;gap:12px}
.zrow{display:grid;grid-template-columns:1.4fr repeat(4,1fr) auto;gap:12px;align-items:center;background:linear-gradient(180deg,var(--panel),var(--panel2));border:1px solid var(--line-soft);border-radius:14px;padding:14px 16px}
@media(max-width:860px){.zrow{grid-template-columns:1fr 1fr;gap:8px}}
.zrow.flag{box-shadow:inset 3px 0 0 var(--neg)}
.zrow .name{font-weight:800;font-size:15.5px}
.zrow .name small{display:block;color:var(--ink-soft);font-weight:500;font-size:11.5px;margin-top:2px}
.metric{font-size:13px;color:var(--ink-soft)}
.metric b{display:block;font-size:16px;color:var(--ink);font-weight:700;font-family:'Manrope'}
.metric b.bad{color:var(--neg)} .metric b.good{color:var(--pos)}
.bar{height:6px;border-radius:4px;background:var(--panel3);overflow:hidden;margin-top:5px}
.bar i{display:block;height:100%;border-radius:4px;background:linear-gradient(90deg,var(--gold-deep),var(--gold))}
.lagpill{font-size:11px;font-weight:800;padding:5px 10px;border-radius:999px;white-space:nowrap}
.lagpill.hi{background:rgba(224,121,95,.16);color:var(--neg)}
.lagpill.mid{background:rgba(232,184,78,.16);color:var(--warn)}
.lagpill.lo{background:rgba(111,191,115,.15);color:var(--pos)}

/* Чат із Софією */
.chatwrap{display:flex;flex-direction:column;height:calc(100vh - 150px);min-height:420px}
.chat{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:14px;padding:6px 2px 16px}
.msg{max-width:80%;padding:13px 16px;border-radius:16px;font-size:14.5px;line-height:1.55;animation:fade .25s}
.msg.s{align-self:flex-start;background:linear-gradient(135deg,rgba(224,179,74,.14),rgba(224,179,74,.05));border:1px solid var(--line);border-bottom-left-radius:5px}
.msg.u{align-self:flex-end;background:var(--panel3);border:1px solid var(--line-soft);border-bottom-right-radius:5px}
.msg .who{font-family:'Prata',serif;color:var(--gold-2);font-size:13px;margin-bottom:4px}
.msg table{width:100%;border-collapse:collapse;margin-top:8px;font-size:13px}
.msg td{padding:4px 8px;border-bottom:1px solid var(--line-soft)}
.suggest{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0}
.suggest button{background:var(--panel);border:1px solid var(--line-soft);color:var(--ink-soft);padding:8px 13px;border-radius:999px;font:inherit;font-size:12.5px;cursor:pointer}
.suggest button:hover{border-color:var(--line);color:var(--gold-2)}
.composer{display:flex;gap:10px;align-items:center;padding-top:12px;border-top:1px solid var(--line-soft)}
.composer input{flex:1;background:var(--panel);border:1px solid var(--line-soft);border-radius:14px;padding:14px 16px;color:var(--ink);font:inherit;font-size:14.5px}
.composer input:focus{outline:none;border-color:var(--gold)}
.composer button{border:none;border-radius:14px;width:50px;height:50px;flex:none;cursor:pointer;font-size:18px;
  background:linear-gradient(135deg,var(--gold-2),var(--gold-deep));color:#3a2a08;box-shadow:0 8px 20px rgba(224,179,74,.3)}
.composer .mic{background:var(--panel);color:var(--gold-2);border:1px solid var(--line-soft)}
.composer .mic.rec{background:var(--neg);color:#fff;animation:pulse 1.2s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(224,121,95,.5)}70%{box-shadow:0 0 0 12px rgba(224,121,95,0)}}
.typing{display:inline-flex;gap:4px}
.typing i{width:6px;height:6px;border-radius:50%;background:var(--gold);animation:blink 1.2s infinite}
.typing i:nth-child(2){animation-delay:.2s}.typing i:nth-child(3){animation-delay:.4s}
@keyframes blink{0%,60%,100%{opacity:.25}30%{opacity:1}}

.divider{height:1px;background:var(--line-soft);margin:22px 0}
.muted{color:var(--ink-soft)}
.tiny{font-size:11.5px;color:var(--ink-dim)}
.pill-demo{display:inline-block;background:rgba(224,179,74,.12);border:1px solid var(--line);color:var(--gold-2);font-size:11px;font-weight:700;padding:3px 10px;border-radius:999px;letter-spacing:.4px}
.src{font-size:11px;color:var(--ink-dim);margin-top:4px}
.src a{color:var(--gold-dim)}

/* Екран входу власника */
.login-screen{position:fixed;inset:0;z-index:80;display:grid;place-items:center;padding:24px;
  background:
    radial-gradient(900px 500px at 50% -10%, rgba(224,179,74,.12), rgba(224,179,74,0) 55%),
    linear-gradient(180deg,var(--bg),var(--bg2))}
.login-card{width:min(380px,92vw);background:linear-gradient(180deg,var(--panel),var(--panel2));border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow),0 0 50px rgba(224,179,74,.08);padding:32px 26px;text-align:center}
.login-mark{width:64px;height:64px;border-radius:50%;margin:0 auto 14px;display:grid;place-items:center;
  background:radial-gradient(circle at 38% 30%, #fff2cf, #e0b34a 52%, #b07d1e);box-shadow:0 8px 24px rgba(224,179,74,.4)}
.login-mark span{font-family:'Prata',serif;font-size:32px;color:#3a2a08;margin-top:3px}
.login-card h2{font-family:'Prata',serif;font-weight:400;font-size:28px;margin:0}
.login-sub{color:var(--ink-soft);font-size:13px;margin:6px 0 22px}
.login-card input{width:100%;background:var(--bg);border:1px solid var(--line-soft);border-radius:13px;padding:14px 16px;color:var(--ink);font:inherit;font-size:15px;text-align:center;letter-spacing:1px}
.login-card input:focus{outline:none;border-color:var(--gold)}
.login-btn{width:100%;margin-top:12px;border:none;border-radius:13px;padding:14px;font:inherit;font-weight:700;font-size:15px;cursor:pointer;
  background:linear-gradient(135deg,var(--gold-2),var(--gold-deep));color:#3a2a08;box-shadow:0 8px 22px rgba(224,179,74,.3)}
.login-btn:active{transform:translateY(1px)}
.login-btn[disabled]{opacity:.6;cursor:default}
.login-err{color:var(--neg);font-size:13px;min-height:18px;margin-top:12px}
