/* Morning Digest v2 — Swiss-editorial, deck-coherent
   규율 종합: Vignelli Canon(그리드·2크기·색=식별자·여백·스케일대비) +
   Müller-Brockmann(모듈 격자·flush-left·데이터를 크게) +
   NYT data-viz(tabular-nums·선언적 헤드라인·1액센트+나머지 회색·무인터랙션 가독) +
   frontend-design(제네릭 회피·1회 오케스트레이션 로드). 덱 팔레트/Pretendard 일치. */

:root{
  /* 덱과 동일 팔레트 — 색은 식별자(데이터=sage, 액센트=clay 1개) */
  --paper:#F4F1EA; --ink:#1A1C22; --d-bg:#16181E;
  --accent:#CC785C;          /* 클레이 — 유일 액센트/링크 */
  --sage:#4F8A82;            /* 신호색 — 데이터/숫자 전용 */
  --soft:#565A62;            /* 보조 텍스트(고대비 유지) */
  --line:#D3CFC5;            /* 하이라인(그리드 룰러) */
  --mute:#938E84;            /* 비활성 */
  --d-soft:#C9C6BD;          /* 다크 위 보조(밝은 홀 washout 보험) */
  --white:#FFFFFF;
  --face:'Pretendard',system-ui,-apple-system,'Apple SD Gothic Neo','Malgun Gothic','Noto Sans KR','Helvetica Neue','Arial',sans-serif;
  --maxw:1040px;
  --gut:24px;
  --num:"tnum" 1, "lnum" 1;  /* tabular-nums: 숫자 흔들림 방지 */
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0; background:var(--paper); color:var(--ink);
  font-family:var(--face); font-size:17px; line-height:1.6;
  word-break:keep-all; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
h1,h2,h3,h4{margin:0; font-weight:700; line-height:1.18; letter-spacing:-0.01em;}
a{color:inherit;}
.num{font-feature-settings:var(--num); font-variant-numeric:tabular-nums;}
.muted{color:var(--soft);}

/* 1회 오케스트레이션 로드 — 스태거 페이드업 */
@keyframes rise{from{opacity:0; transform:translateY(14px);} to{opacity:1; transform:none;}}
.rise{animation:rise .6s cubic-bezier(.2,.7,.2,1) both;}
@media (prefers-reduced-motion:reduce){.rise{animation:none;}}

/* ───────────── 그리드 셸 ───────────── */
.wrap{max-width:var(--maxw); margin:0 auto; padding:0 var(--gut);}

/* ───────────── 마스트헤드 (flush-left) ───────────── */
.mast{max-width:var(--maxw); margin:0 auto; padding:34px var(--gut) 0;}
.mast-top{display:flex; align-items:baseline; justify-content:space-between; gap:16px; flex-wrap:wrap;}
.mast-kicker{font-size:11px; letter-spacing:.26em; text-transform:uppercase; color:var(--accent); font-weight:700;}
.mast-date{font-size:12.5px; color:var(--soft); letter-spacing:.02em;}
.mast-title{font-size:clamp(38px,6vw,60px); font-weight:800; letter-spacing:-0.02em; margin:6px 0 0;}
.mast-sub{font-size:16px; color:var(--soft); margin:6px 0 0;}
.rule{border:0; border-top:2px solid var(--ink); margin:18px 0 0;}   /* 2pt 메이저 룰러 */
.rule-thin{border:0; border-top:1px solid var(--line);}

/* ───────────── 히어로 데이터 밴드 (임팩트=오버행 텔레그래프) ───────────── */
.hero{max-width:var(--maxw); margin:0 auto; padding:26px var(--gut) 0;}
.hero-lead{font-size:clamp(20px,2.6vw,26px); font-weight:700; line-height:1.4; max-width:30em;}
.hero-lead .hl{color:var(--accent);}
.hero-transform{display:flex; align-items:flex-end; gap:clamp(18px,4vw,44px); margin-top:22px;
  border-top:1px solid var(--line); padding-top:18px;}
.ht-before,.ht-after{display:flex; flex-direction:column; gap:8px;}
.ht-n{font-size:clamp(32px,5.6vw,56px); font-weight:800; line-height:1; letter-spacing:-0.02em;
  font-feature-settings:var(--num);}
.ht-before .ht-n{color:var(--soft);}        /* before=과거/문제 = 회색(절제) */
.ht-after  .ht-n{color:var(--sage);}        /* after=결과 = 신호색(데이터 규율 준수) */
.ht-n small{font-size:.40em; font-weight:700; margin-left:4px; letter-spacing:0;}
.ht-l{font-size:12.5px; color:var(--soft); letter-spacing:.02em;}
.ht-arrow{font-size:clamp(26px,4vw,40px); color:var(--accent); font-weight:700; line-height:1; padding-bottom:.35em;}
.hero-foot{margin-top:13px; font-size:13px; color:var(--soft); letter-spacing:.01em; font-feature-settings:var(--num);}
.hero-foot .num{color:var(--ink); font-weight:700;}
@media (max-width:520px){ .hero-transform{gap:14px;} .ht-arrow{padding-bottom:.2em;} }

/* ───────────── 섹션 공통 ───────────── */
section{max-width:var(--maxw); margin:0 auto; padding:0 var(--gut);}
.sec{margin-top:56px;}
.sec-head{display:flex; align-items:baseline; gap:14px; border-bottom:2px solid var(--ink); padding-bottom:10px;}
.sec-no{font-size:13px; font-weight:800; color:var(--accent); letter-spacing:.08em;}
.sec-head h2{font-size:23px;}
.sec-note{margin-left:auto; font-size:12.5px; color:var(--soft);}

/* ───────────── 위클리 시그널 (선언적 헤드라인 = 페이오프) ───────────── */
.signal{margin-top:22px;}
.signal-kicker{font-size:11px; letter-spacing:.24em; text-transform:uppercase; color:var(--accent); font-weight:700;}
.signal-body{margin-top:12px;}
.signal-body p{
  font-size:clamp(18px,2.3vw,23px); font-weight:600; line-height:1.5; margin:0 0 14px;
  padding-left:22px; position:relative; max-width:40em;
}
.signal-body p::before{content:""; position:absolute; left:0; top:.55em; width:11px; height:3px; background:var(--accent);}

/* ───────────── 인사이트 (출처 검증이 주인공) ───────────── */
.ins-head{display:flex; align-items:baseline; justify-content:space-between; gap:16px; flex-wrap:wrap; margin-top:40px;}
.ins-head h3{font-size:18px;}
.legend{font-size:12px; color:var(--soft);}
.legend .flag{margin:0 4px 0 12px;}
.flag{display:inline-block; font-size:10px; font-weight:800; letter-spacing:.12em; padding:2px 8px; border-radius:2px; vertical-align:1px;}
.flag-high{background:var(--accent); color:var(--white);}
.flag-medium{background:transparent; color:var(--soft); border:1px solid var(--line);}

/* P2-a: 번호 카운터 제거 (counter-reset/increment/::before 전부 삭제) */
.insights{list-style:none; margin:14px 0 0; padding:0;}
.insight{position:relative; padding:20px 0 20px 18px; border-top:1px solid var(--line);}
.insight::before{content:none;}                 /* 01,02… 번호 제거 */
.insight.high{box-shadow:inset 3px 0 0 var(--accent);}  /* HIGH 표식=좌측 룰러 */
.ins-meta{margin:0 0 7px;}                       /* flag 한 줄(위계는 flag가 짐) */
.ins-lead{margin:0; font-size:17px; font-weight:700; line-height:1.5; letter-spacing:-0.005em; color:var(--ink);}
.insight.high .ins-lead{font-size:17.5px;}
.ins-lead--plain{font-weight:600; font-size:16px;}      /* 폴백: 덜 강하게 */
.ins-body{margin:5px 0 0; font-size:14.5px; font-weight:400; line-height:1.6; color:var(--soft);}

/* P0-3: 본문 인용 = 2줄 클램프 + 토글 (한국어 lead가 시각 지배) */
.ins-quote{margin:11px 0 4px; padding:9px 15px; border-left:2px solid var(--sage);
  background:rgba(79,138,130,.06); font-size:13.5px; color:var(--soft); line-height:1.55;
  overflow-wrap:anywhere;
  display:-webkit-box; -webkit-box-orient:vertical; -webkit-line-clamp:2; overflow:hidden;}
.ins-quote.open{-webkit-line-clamp:unset; display:block; overflow:visible;}
.quote-more{display:block; margin:5px 0 8px; background:none; border:0; padding:0;
  font-family:var(--face); font-size:12px; font-weight:700; color:var(--accent); cursor:pointer;}
.quote-more[hidden]{display:none !important;}   /* author display가 UA [hidden]를 덮어쓰지 않도록 명시 가드 */
.quote-more:hover{text-decoration:underline;}
.insights-med .ins-quote{-webkit-line-clamp:2;}

/* P0-1: MEDIUM 접기 (테이크홈 톤: 작게·연하게) */
.med-toggle-row{padding:14px 0 0; border-top:1px solid var(--line);}
.med-toggle{font-family:var(--face); font-size:12.5px; font-weight:700; letter-spacing:.04em;
  background:transparent; color:var(--soft); border:1px solid var(--line); border-radius:3px;
  padding:9px 16px; cursor:pointer; transition:border-color .15s,color .15s;}
.med-toggle:hover{border-color:var(--accent); color:var(--accent);}
.med-toggle[aria-expanded="true"]{color:var(--soft);}
.med-wrap[hidden]{display:none;}
.insights-med{list-style:none; margin:14px 0 0; padding:0;}
.insights-med .insight{padding-top:16px; padding-bottom:16px;}
.insights-med .ins-lead{font-size:15px; font-weight:600; color:var(--soft);}
.insights-med .ins-body{font-size:13px; color:var(--soft);}
.insights-med .flag-medium{opacity:.85;}

/* P1-6: 시각 초점 — 최상위 HIGH 콜아웃 (가짜 차트 금지) */
.insight-focal{margin:18px 0 6px;}
.insight-focal[hidden]{display:none;}
.focal-card{border:1px solid rgba(204,120,92,.45); border-left:4px solid var(--accent);
  background:rgba(204,120,92,.05); border-radius:6px; padding:22px 24px;}
.focal-kicker{margin:0 0 12px; display:flex; align-items:center; gap:8px;
  font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); font-weight:700;}
.focal-lead{margin:0; font-size:clamp(19px,2.4vw,23px); font-weight:800; line-height:1.42;
  letter-spacing:-0.01em; color:var(--ink); max-width:34em;}
.focal-body{margin:9px 0 0; font-size:15px; line-height:1.6; color:var(--soft); max-width:42em;}
.focal-quote{margin:14px 0 12px; padding:10px 16px; border-left:2px solid var(--sage);
  background:rgba(79,138,130,.07); font-size:14px; color:var(--soft); line-height:1.55;
  max-width:44em; overflow-wrap:anywhere;
  display:-webkit-box; -webkit-box-orient:vertical; -webkit-line-clamp:3; overflow:hidden;}
/* 출처 검증 줄 = 데모의 파운데이션 → 또렷하게 */
.src{display:inline-flex; align-items:center; gap:7px; margin-top:4px; font-size:13px; color:var(--soft); flex-wrap:wrap;}
.src .src-name{font-weight:600; color:var(--ink);}
.src-jump{display:inline-flex; align-items:center; gap:5px; font-weight:700; color:var(--accent);
  text-decoration:none; border:1px solid rgba(204,120,92,.4); border-radius:3px; padding:2px 9px;
  font-feature-settings:var(--num);}
.src-jump:hover{background:var(--accent); color:var(--white); border-color:var(--accent);}
.src-doc{display:inline-flex; align-items:center; gap:5px; font-weight:700; color:var(--sage);
  text-decoration:none; border:1px solid rgba(79,138,130,.4); border-radius:3px; padding:2px 9px;}
.src-doc:hover{background:var(--sage); color:var(--white); border-color:var(--sage);}

/* ───────────── watch/skip + 검증필요 (2단) ───────────── */
.two{display:grid; grid-template-columns:1fr 1fr; gap:36px; margin-top:48px; border-top:1px solid var(--line); padding-top:8px;}  /* 상단 무대와 격리 룰러 */
@media (max-width:720px){.two{grid-template-columns:1fr;}}
.ws{list-style:none; margin:0; padding:0;}
.ws li{padding:11px 0; border-top:1px solid var(--line); font-size:14px; line-height:1.5;}
.ws li:first-child{border-top:0;}
.verdict{display:inline-block; font-size:10px; font-weight:800; letter-spacing:.1em; padding:2px 8px; border-radius:2px; margin-right:7px;}
.v-watch{background:var(--sage); color:var(--white);}
.v-skip{background:transparent; color:var(--soft); border:1px solid var(--line);}
.ws-title{font-weight:600;}
.ws-reason{color:var(--soft); font-size:13px; margin-top:2px;}
.lc-note{font-size:12.5px; color:var(--soft); margin:0 0 10px;}
.lc{list-style:none; margin:0; padding:0;}
.lc li{position:relative; padding:9px 0 9px 18px; border-top:1px dotted var(--line); font-size:13.5px; color:#3a3d43; line-height:1.5;}
.lc li::before{content:"†"; position:absolute; left:0; color:var(--accent);}

/* ───────────── 구독 채널 (카탈로그) ───────────── */
.cat-desc{margin:14px 0 0; font-size:14.5px; color:var(--soft); max-width:46em;}
.cat-desc strong{color:var(--ink); font-weight:700;}
.catalog{margin-top:26px; display:flex; flex-direction:column; gap:30px;}
.cat-group-title{font-size:12px; font-weight:800; letter-spacing:.14em; text-transform:uppercase;
  display:flex; align-items:baseline; gap:10px; border-bottom:1px solid var(--line); padding-bottom:7px;}
.cat-group-note{font-weight:600; letter-spacing:.02em; font-size:11.5px; color:var(--sage); text-transform:none;}
/* P2-c: 카탈로그 그룹 데스크톱에서도 기본 접기(첫 그룹만 open) */
details.cat-group{margin:0;}                     /* .catalog의 gap:30px가 그룹 간격 담당 */
details.cat-group>summary{list-style:none; cursor:pointer; align-items:center;}
details.cat-group>summary::-webkit-details-marker{display:none;}
details.cat-group>summary::after{content:"＋"; margin-left:10px; color:var(--accent); font-weight:700;}
details.cat-group[open]>summary::after{content:"－";}
.cat-group-count{font-weight:600; font-size:11px; color:var(--mute); letter-spacing:.02em; text-transform:none; margin-left:auto;}
details.cat-group>.cat-sources{margin-top:14px;}
.cat-sources{margin-top:12px; display:grid; grid-template-columns:1fr 1fr; gap:10px;}
@media (max-width:720px){.cat-sources{grid-template-columns:1fr;}}
.cat-source{border:1px solid var(--line); border-radius:5px; padding:13px 15px; background:rgba(255,255,255,.4);
  transition:border-color .15s, box-shadow .15s;}
.cat-source.has-selected{border-color:var(--accent); box-shadow:inset 3px 0 0 var(--accent);}
.cat-source.unavailable{opacity:.55;}
.cat-source-head{display:flex; gap:10px; align-items:flex-start;}
.src-all{margin-top:3px; accent-color:var(--accent); width:16px; height:16px; cursor:pointer; flex-shrink:0;}
.cat-src-main{flex:1; min-width:0;}
.cat-src-titlerow{display:flex; align-items:baseline; gap:7px; flex-wrap:wrap;}
.cat-src-name{font-size:15px; font-weight:700;}
.cat-src-cat{font-size:10px; font-weight:700; color:var(--soft); border:1px solid var(--line); border-radius:999px; padding:1px 8px;}
.cat-src-pub{font-size:11px; color:var(--mute);}
.cat-src-blurb{margin:5px 0 0; font-size:12.5px; color:var(--soft); line-height:1.5;}
.cat-status{margin-top:8px; font-size:11px; display:flex; align-items:center; gap:8px;}
.dot{width:6px; height:6px; border-radius:50%; background:var(--sage); flex-shrink:0;}
.dot.off{background:var(--mute);}
.cat-status .st-ok{color:var(--sage); font-weight:700;}
.cat-status .st-off{color:var(--mute); font-weight:700;}
.cat-status .st-meta{color:var(--soft); font-feature-settings:var(--num);}
.cat-items{list-style:none; margin:10px 0 0; padding:10px 0 0; border-top:1px dotted var(--line); display:flex; flex-direction:column; gap:7px;}
.cat-item{display:flex; gap:9px; align-items:flex-start; font-size:13px; cursor:pointer;}
.cat-item input{margin-top:3px; accent-color:var(--accent); flex-shrink:0;}
.ci-title{font-weight:600; line-height:1.4;}
.ci-meta{display:block; font-size:11px; color:var(--mute); margin-top:1px; font-feature-settings:var(--num);}
.ci-meta .ci-kind{color:var(--accent); font-weight:700; margin-right:5px;}
.cat-empty{font-size:12px; color:var(--mute); font-style:italic; margin:8px 0 0;}
/* P1-7: 빈/실패 소스 = '준비 중' 1줄 배지로 축약 */
.cat-source.pending{opacity:.6; background:transparent; padding:11px 15px;}
.cat-source.pending .cat-src-titlerow{align-items:center;}
.cat-pending-badge{font-size:10px; font-weight:800; letter-spacing:.1em; text-transform:uppercase;
  color:var(--soft); border:1px solid var(--line); border-radius:999px; padding:1px 9px; margin-left:auto;}

/* 페르소나 + 직접추가 + 액션 */
.persona{margin-top:30px;}
.field-label{font-size:12px; font-weight:800; letter-spacing:.12em; text-transform:uppercase; display:flex; align-items:center; gap:8px; margin-bottom:10px;}
.field-hint{font-weight:600; letter-spacing:.04em; font-size:11px; color:var(--mute); text-transform:none;}
textarea{width:100%; resize:vertical; min-height:120px; padding:13px 15px; background:var(--white); border:1px solid var(--line); border-radius:5px;
  font-family:var(--face); font-size:14.5px; line-height:1.65; color:var(--ink);}
textarea:focus{outline:2px solid var(--accent); outline-offset:-1px;}
details.manual{margin-top:22px;}
details.manual>summary{cursor:pointer; font-size:12px; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:var(--soft);}
details.manual[open]>summary{margin-bottom:12px;}
.manual-note{font-size:12.5px; color:var(--soft); margin:0 0 12px;}
.public-only{color:#A93D2A; font-weight:700;}
.src-inputs{display:grid; grid-template-columns:1.4fr 1fr; gap:14px;}
@media (max-width:620px){.src-inputs{grid-template-columns:1fr;}}
.url-row{display:flex; gap:8px;}
.url-row input{flex:1; min-width:0; padding:10px 12px; background:var(--white); border:1px solid var(--line); border-radius:5px; font-family:var(--face); font-size:14px; color:var(--ink);}
.url-row input:focus{outline:2px solid var(--accent); outline-offset:-1px;}
.btn-ghost{font-family:var(--face); font-size:14px; font-weight:700; background:transparent; color:var(--ink); border:1px solid var(--ink); border-radius:3px; padding:0 16px; cursor:pointer; white-space:nowrap;}
.btn-ghost:hover{border-color:var(--accent); color:var(--accent);}
.dropzone{display:flex; align-items:center; justify-content:center; text-align:center; background:var(--white); border:1.5px dashed var(--line); border-radius:5px; padding:13px; cursor:pointer; min-height:44px;}
.dropzone:hover,.dropzone.dragover{border-color:var(--accent); background:rgba(204,120,92,.05);}
.dz-text{font-size:12.5px; color:var(--soft);}
.chips{list-style:none; margin:14px 0 0; padding:0; display:flex; flex-wrap:wrap; gap:8px;}
.chip{display:inline-flex; align-items:center; gap:8px; max-width:320px; background:var(--white); border:1px solid var(--line); border-radius:999px; padding:6px 10px 6px 12px; font-size:12.5px;}
.chip.done{border-color:var(--sage);} .chip.error{border-color:#A93D2A;}
.chip-icon{font-size:10px; font-weight:700;} .chip.url .chip-icon{color:var(--accent);} .chip.pdf .chip-icon{color:var(--sage);}
.chip-label{overflow:hidden; text-overflow:ellipsis; white-space:nowrap;}
.chip-status{font-size:11px; color:var(--soft);}
.chip.loading .chip-status{color:var(--accent);} .chip.done .chip-status{color:var(--sage);} .chip.error .chip-status{color:#A93D2A;}
.chip-x{border:0; background:none; cursor:pointer; font-size:14px; color:var(--mute); padding:0 2px;}
.chip-x:hover{color:#A93D2A;}
.chip-spin{width:9px; height:9px; border-radius:50%; border:1.5px solid rgba(204,120,92,.3); border-top-color:var(--accent); animation:spin .7s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}

.action{margin-top:26px; display:flex; align-items:center; gap:14px; flex-wrap:wrap;}
.btn{font-family:var(--face); font-size:15px; font-weight:700; letter-spacing:.01em; background:var(--ink); color:var(--paper); border:0; border-radius:3px; padding:13px 28px; cursor:pointer; transition:background .15s;}
.btn:hover{background:var(--accent);}
.btn:disabled{background:var(--mute); cursor:wait;}
.action-note{font-size:12.5px; color:var(--soft); max-width:320px; line-height:1.5;}
.err{color:#A93D2A; font-size:13.5px; margin-top:10px;}

/* P2-b: 다이제스트 직후 구독 CTA (1차 진입점) */
.digest-cta{margin-top:40px; padding:20px 24px; border:1px solid var(--line); border-radius:7px;
  background:rgba(204,120,92,.05); display:flex; align-items:center; justify-content:space-between;
  gap:18px; flex-wrap:wrap;}
.dc-text{margin:0; font-size:15px; font-weight:600; color:var(--ink);}
.dc-btn{flex-shrink:0; text-decoration:none; display:inline-block;}

/* 로딩 */
.loading{text-align:center; padding:44px 20px; border-top:1px solid var(--line); border-bottom:1px solid var(--line); margin-top:30px;}
.pulse{width:10px; height:10px; border-radius:50%; background:var(--accent); margin:0 auto 16px; animation:pp 1.2s ease-in-out infinite;}
@keyframes pp{0%,100%{transform:scale(1); opacity:1;} 50%{transform:scale(2.2); opacity:.35;}}
.loading-stage{font-size:18px; font-weight:700; margin:0;}
.loading-sub{font-size:13px; color:var(--soft); margin:8px 0 0;}

/* ───────────── 구독 (다크) ───────────── */
.subscribe{margin-top:64px;}
.sub-inner{background:var(--d-bg); color:var(--paper); border-radius:7px; padding:42px 44px;}
@media (max-width:600px){.sub-inner{padding:30px 22px;}}
.sub-kicker{font-size:11px; letter-spacing:.26em; text-transform:uppercase; color:var(--accent); font-weight:700;}
.sub-inner h2{font-size:25px; color:var(--paper); margin-top:8px;}
.sub-desc{color:var(--d-soft); max-width:540px; margin:11px 0 24px; font-size:14.5px;}
.form-grid{display:grid; grid-template-columns:1fr 1fr; gap:15px 18px;}
@media (max-width:600px){.form-grid{grid-template-columns:1fr;}}
.form-grid label{display:flex; flex-direction:column; gap:6px; font-size:11px; font-weight:700; letter-spacing:.06em; color:var(--d-soft);}
.form-grid input{background:rgba(244,241,234,.08); border:1px solid rgba(244,241,234,.25); border-radius:3px; padding:11px 13px; color:var(--paper); font-family:var(--face); font-size:14.5px;}
.form-grid input::placeholder{color:rgba(244,241,234,.35);}
.form-grid input:focus{outline:2px solid var(--accent); outline-offset:-1px;}
.sub-btn{background:var(--accent); color:var(--white); margin-top:4px;}
.sub-btn:hover{background:#b5654a;}
.sub-result{font-size:13.5px; color:var(--sage);}
.sub-result.ok{color:#8FC7B6;} .sub-result.err{color:#E0907A;}

/* 푸터 */
.foot{max-width:var(--maxw); margin:22px auto 0; padding:0 var(--gut) 46px;}
.foot .rule-thin{margin-bottom:14px;}
.foot p{font-size:12px; color:var(--mute); margin:0;}
.foot .pw{margin-top:5px; color:var(--accent); letter-spacing:.03em;}

/* 게이트 */
.gate{position:fixed; inset:0; z-index:100; background:rgba(22,24,30,.6); backdrop-filter:blur(3px); display:flex; align-items:center; justify-content:center; padding:24px;}
.gate[hidden]{display:none!important;}
.gate-card{background:var(--paper); border-radius:8px; padding:38px 38px 32px; max-width:420px; width:100%; box-shadow:0 20px 60px rgba(22,24,30,.4);}
.gate-card h2{font-size:22px;} .gate-kicker{font-size:11px; letter-spacing:.26em; text-transform:uppercase; color:var(--accent); font-weight:700; margin:0 0 8px;}
.gate-desc{margin:12px 0 20px; font-size:14px; color:var(--soft);}
#gateForm{display:flex; gap:10px;}
#gateInput{flex:1; min-width:0; padding:12px 14px; text-align:center; letter-spacing:.08em; background:var(--white); border:1px solid var(--line); border-radius:5px; font-family:var(--face); font-size:16px;}
#gateInput:focus{outline:2px solid var(--accent); outline-offset:-1px;}
.gate-err{color:#A93D2A; font-size:13px; margin:14px 0 0;}
