/* ESTELAVIA — закрытый показ. Чёрно-белый минимализм под estelavia.ru. */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600&family=Jost:wght@300;400;500&display=swap');

:root{
  --bg:#ffffff;
  --paper:#faf9f7;
  --ink:#141414;
  --ink-soft:#3a3a3a;
  --muted:#8c867d;
  --line:#e7e3dc;
  --line-strong:#cfc9c0;
  --ok:#3f6f4f;
  --ok-bg:#eef3ee;
  --warn:#8a6d22;
  --warn-bg:#f6f1e3;
  --danger:#9b3b3b;
  --danger-bg:#f6ecea;
  --shadow:0 1px 0 rgba(0,0,0,.02), 0 12px 40px -24px rgba(0,0,0,.25);
  --radius:2px;
}

*{box-sizing:border-box}
html{overflow-x:clip}
html,body{margin:0;padding:0;max-width:100%}
body{
  font-family:'Jost',-apple-system,Segoe UI,Roboto,sans-serif;
  font-weight:300;
  color:var(--ink);
  background:var(--bg);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}

h1,h2,h3{font-family:'Cormorant Garamond',Georgia,serif;font-weight:500;letter-spacing:.01em;margin:0}
h1{font-size:34px;line-height:1.15}
h2{font-size:24px}
h3{font-size:19px}

.serif{font-family:'Cormorant Garamond',Georgia,serif}
.eyebrow{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--muted);font-weight:400}
.muted{color:var(--muted)}
.small{font-size:13px}
.tiny{font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.center{text-align:center}
.nowrap{white-space:nowrap}
.spread{display:flex;align-items:center;justify-content:space-between;gap:16px}

/* ---------- layout ---------- */
.wrap{max-width:1080px;margin:0 auto;padding:0 24px}
.narrow{max-width:560px}
.topbar{border-bottom:1px solid var(--line);background:var(--bg);position:sticky;top:0;z-index:40}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;height:64px;gap:18px}
.brand{font-family:'Cormorant Garamond',serif;font-size:22px;letter-spacing:.42em;text-transform:uppercase;font-weight:500}
.brand small{display:block;font-family:'Jost';font-size:9.5px;letter-spacing:.34em;color:var(--muted);font-weight:400;margin-top:-2px}
.topnav{display:flex;gap:26px;align-items:center}
.topnav a,.topnav button{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);background:none;border:0;cursor:pointer;font-family:inherit;padding:6px 0;border-bottom:1px solid transparent;transition:.15s}
.topnav a:hover,.topnav button:hover,.topnav a.active{color:var(--ink);border-color:var(--ink)}

section.hero{padding:48px 0 40px;border-bottom:1px solid var(--line)}
.hero-grid{display:grid;grid-template-columns:auto 1fr;gap:52px;align-items:center}
.hero-media{position:relative;aspect-ratio:400/711;height:540px;width:auto;max-width:100%;
  margin-inline:auto;overflow:hidden;border-radius:2px;background:var(--paper)}
.hero-media img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;filter:saturate(.97) contrast(1.02)}
.hero-tag{position:absolute;left:0;bottom:0;background:rgba(20,18,16,.5);color:#fff;font-size:10px;letter-spacing:.34em;text-transform:uppercase;padding:8px 15px}
.hero-copy h1{margin:14px 0 12px}
.hero-meta{font-size:15px;letter-spacing:.04em;margin-bottom:16px}
.hero-copy .btn{margin-top:22px}
@media(max-width:760px){
  .hero-grid{grid-template-columns:1fr;gap:26px}
  .hero-media{height:64vh;max-height:540px;aspect-ratio:400/711}
  .hero-copy{text-align:center}
}
.section{padding:32px 0}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:'Jost';font-weight:400;font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  background:var(--ink);color:#fff;border:1px solid var(--ink);
  padding:13px 24px;border-radius:var(--radius);cursor:pointer;transition:.15s;
}
.btn:hover{background:#000;border-color:#000}
.btn:disabled{opacity:.4;cursor:not-allowed}
.btn.ghost{background:transparent;color:var(--ink)}
.btn.ghost:hover{background:var(--paper)}
.btn.sm{padding:8px 14px;font-size:10.5px;letter-spacing:.16em}
.btn.block{width:100%}
.btn.ok{background:var(--ok);border-color:var(--ok)}
.btn.danger{background:var(--danger);border-color:var(--danger)}
.btn.danger.ghost{background:transparent;color:var(--danger)}
.linkbtn{background:none;border:0;color:var(--muted);font-family:inherit;cursor:pointer;font-size:12px;letter-spacing:.1em;text-transform:uppercase;border-bottom:1px solid transparent;padding:2px 0}
.linkbtn:hover{color:var(--ink);border-color:var(--ink)}

/* ---------- forms ---------- */
.field{margin-bottom:18px}
.field label,.lbl{display:block;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:7px}
input[type=text],input[type=tel],input[type=email],input[type=password],input[type=number],textarea,select{
  width:100%;font-family:'Jost';font-weight:300;font-size:15px;color:var(--ink);
  background:var(--bg);border:1px solid var(--line-strong);border-radius:var(--radius);
  padding:11px 13px;transition:.15s;
}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--ink)}
textarea{resize:vertical;min-height:64px}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.checkbox{display:flex;gap:10px;align-items:flex-start;font-size:13.5px;color:var(--ink-soft);cursor:pointer}
.checkbox input{width:auto;margin-top:3px}
.hint{font-size:12px;color:var(--muted);margin-top:5px}

/* attendee rows */
.att-row{display:flex;gap:8px;margin-bottom:8px}
.att-row input{flex:1}
.icon-btn{border:1px solid var(--line-strong);background:var(--bg);width:42px;border-radius:var(--radius);cursor:pointer;font-size:18px;color:var(--muted)}
.icon-btn:hover{border-color:var(--ink);color:var(--ink)}

/* ---------- cards / panels ---------- */
.card{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);padding:26px}
.card.soft{background:var(--paper)}
.panel{background:var(--bg);border:1px solid var(--line);border-radius:var(--radius)}
.panel-h{padding:18px 22px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:12px}
.panel-b{padding:22px}

/* ---------- chips / badges ---------- */
.chip{display:inline-flex;align-items:center;gap:6px;font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;
  padding:4px 10px;border-radius:20px;border:1px solid var(--line-strong);color:var(--muted)}
.chip.new{background:var(--bg);color:var(--ink);border-color:var(--ink)}
.chip.confirmed{background:var(--ok-bg);color:var(--ok);border-color:transparent}
.chip.rejected{background:var(--danger-bg);color:var(--danger);border-color:transparent}
.chip.arrived{background:#141414;color:#fff;border-color:#141414}
.chip.dup{background:var(--warn-bg);color:var(--warn);border-color:transparent}

/* ---------- stats ---------- */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;margin-bottom:24px}
.stat{background:var(--bg);padding:16px 18px}
.stat .n{font-family:'Cormorant Garamond',serif;font-size:30px;line-height:1}
.stat .t{font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:6px}

/* ---------- table of registrations ---------- */
.toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:18px}
.tabs{display:flex;gap:4px;flex-wrap:wrap}
.tabs button{font-size:11px;letter-spacing:.12em;text-transform:uppercase;background:none;border:1px solid var(--line-strong);
  border-radius:20px;padding:7px 14px;cursor:pointer;color:var(--muted);font-family:inherit}
.tabs button.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.search{flex:1;min-width:200px}

.reg-list{display:flex;flex-direction:column;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.reg-row{background:var(--bg);padding:15px 18px;display:grid;grid-template-columns:1fr auto;gap:8px 16px;cursor:pointer;transition:.12s}
.reg-row:hover{background:var(--paper)}
.reg-row .main{min-width:0}
.reg-row .salon{font-size:16px;font-weight:400}
.reg-row .sub{font-size:12.5px;color:var(--muted);margin-top:2px}
.reg-row .right{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.code-pill{font-family:'Jost';letter-spacing:.22em;font-size:15px;background:var(--paper);border:1px solid var(--line-strong);padding:4px 12px;border-radius:var(--radius)}

/* ---------- drawer / modal ---------- */
.overlay{position:fixed;inset:0;background:rgba(20,18,16,.34);z-index:60;display:none}
.overlay.show{display:block}
.drawer{position:fixed;top:0;right:0;height:100%;width:min(480px,100%);background:var(--bg);z-index:70;
  transform:translateX(100%);transition:.25s;display:flex;flex-direction:column;box-shadow:var(--shadow)}
.drawer.show{transform:translateX(0)}
.drawer-h{padding:18px 22px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.drawer-b{padding:22px;overflow:auto;flex:1}
.drawer-f{padding:16px 22px;border-top:1px solid var(--line);display:flex;gap:10px;flex-wrap:wrap}
.kv{display:flex;justify-content:space-between;gap:16px;padding:9px 0;border-bottom:1px dotted var(--line);font-size:14px}
.kv .k{color:var(--muted);font-size:12px;letter-spacing:.08em;text-transform:uppercase}
.kv .v{text-align:right}

/* ---------- check-in ---------- */
.checkin-wrap{max-width:560px;margin:0 auto;padding:40px 24px}
.code-input{width:100%;display:block;font-family:'Jost';font-size:42px;letter-spacing:.4em;text-align:center;padding:18px;font-weight:300;border:1px solid var(--line-strong);border-radius:var(--radius);background:var(--bg);color:var(--ink)}
.code-input:focus{outline:none;border-color:var(--ink)}
.result{margin-top:26px;border-radius:var(--radius);border:1px solid var(--line);overflow:hidden}
.result .head{padding:20px 22px;text-align:center}
.result.good .head{background:var(--ok-bg);color:var(--ok)}
.result.bad .head{background:var(--danger-bg);color:var(--danger)}
.result.warnst .head{background:var(--warn-bg);color:var(--warn)}
.result .head .big{font-family:'Cormorant Garamond',serif;font-size:26px}
.result .body{padding:20px 22px}
.tick{display:flex;gap:10px;align-items:center;padding:9px 0;border-bottom:1px dotted var(--line);font-size:15px}
.tick input{width:auto}

/* ---------- flash ---------- */
.flash{position:fixed;left:50%;bottom:26px;transform:translateX(-50%);background:var(--ink);color:#fff;
  padding:12px 22px;border-radius:var(--radius);font-size:13px;letter-spacing:.06em;z-index:90;opacity:0;
  transition:.2s;pointer-events:none;max-width:90vw}
.flash.show{opacity:1}
.flash.err{background:var(--danger)}

/* ---------- misc ---------- */
.divider{height:1px;background:var(--line);margin:26px 0}
.empty{text-align:center;color:var(--muted);padding:50px 20px;font-size:14px}
.foot{border-top:1px solid var(--line);margin-top:48px;padding:28px 0;text-align:center;color:var(--muted);font-size:12px;letter-spacing:.06em}
.sendline{display:flex;gap:8px;align-items:center;font-size:13px;padding:6px 0}
.dot{width:7px;height:7px;border-radius:50%;display:inline-block}
.dot.ok{background:var(--ok)}.dot.no{background:var(--danger)}

@media(max-width:640px){
  h1{font-size:28px}
  .row2{grid-template-columns:1fr}
  .topbar{position:static}
  .topbar .wrap{height:auto;padding-top:12px;padding-bottom:10px;flex-direction:column;align-items:flex-start;gap:10px}
  .topnav{width:100%;gap:8px 16px;flex-wrap:wrap}
  .topnav a,.topnav button{white-space:nowrap;padding:4px 0}
  .reg-row{grid-template-columns:1fr}
  .reg-row .right{justify-content:flex-start}
  .code-input{font-size:34px;letter-spacing:.3em}
  .stat .n{font-size:26px}
  .drawer{width:100%}
}
