/* ============================================================
   Not Taken Yet — Main Stylesheet
   Fraunces (serif display) + Inter (UI sans)
   ============================================================ */

:root {
  --bone:         #F7F5F0;
  --bone-2:       #EFEBE3;
  --ink:          #1A1A1A;
  --ink-soft:     #4A4744;
  --ink-faint:    #8A857E;
  --emerald:      #0F3D2E;
  --emerald-soft: #1F5A45;
  --gold:         #B8985A;
  --line:         rgba(26,26,26,0.12);
  --line-soft:    rgba(26,26,26,0.07);
  --green:        #2F6B4F;
  --amber:        #9A7B2E;
  --red:          #8A3A33;
  --serif: 'Fraunces', Georgia, 'Times New Roman', serif;
  --sans:  'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --ease:  cubic-bezier(0.25, 0, 0.1, 1);
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  background: var(--bone); color: var(--ink);
  font-family: var(--sans); font-weight: 300;
  line-height: 1.6; -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { max-width: 100%; display: block; }
a { color: inherit; }

/* ---- Layout ---- */
.wrap { max-width: 1180px; margin: 0 auto; padding: 0 40px; }

/* ---- Typography ---- */
.eyebrow {
  font-size: 12px; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--ink-faint);
}
.section-head { text-align: center; margin-bottom: 56px; }
.section-head .eyebrow { margin-bottom: 16px; }
.section-head h2 {
  font-family: var(--serif); font-weight: 300;
  font-size: clamp(28px, 4vw, 44px); letter-spacing: -0.01em;
}

/* ============================================================
   NAV
   ============================================================ */
nav {
  display: flex; align-items: center; justify-content: space-between;
  padding: 30px 40px; max-width: 1180px; margin: 0 auto;
  border-bottom: 1px solid var(--line-soft);
}
.wordmark {
  font-family: var(--serif); font-weight: 500;
  font-size: 24px; letter-spacing: 0.14em; text-transform: uppercase;
  text-decoration: none; color: var(--ink);
}
.wordmark span { color: var(--gold); }
.nav-links { display: flex; gap: 38px; align-items: center; }
.nav-links a {
  color: var(--ink-soft); text-decoration: none; font-size: 13px;
  letter-spacing: 0.06em; text-transform: uppercase; transition: color .3s var(--ease);
}
.nav-links a:hover { color: var(--ink); }
.nav-cta {
  border: 1px solid var(--ink); border-radius: 2px;
  padding: 10px 22px !important; color: var(--ink) !important;
  transition: all .25s var(--ease) !important;
}
.nav-cta:hover { background: var(--ink) !important; color: var(--bone) !important; }
.nav-mobile-btn {
  display: none; background: none; border: none; cursor: pointer;
  padding: 6px; flex-direction: column; gap: 5px;
}
.nav-mobile-btn span {
  display: block; width: 22px; height: 1px; background: var(--ink);
  transition: all .3s var(--ease);
}

/* ============================================================
   HERO
   ============================================================ */
.hero { text-align: center; padding: 110px 0 40px; }
.hero .eyebrow { margin-bottom: 34px; }
.hero h1 {
  font-family: var(--serif); font-weight: 300;
  font-size: clamp(38px, 6.2vw, 78px); line-height: 1.04;
  letter-spacing: -0.01em; max-width: 14ch; margin: 0 auto 30px;
}
.hero h1 em { font-style: italic; color: var(--emerald); }
.hero p.lede {
  font-size: clamp(16px, 1.6vw, 19px); color: var(--ink-soft);
  max-width: 52ch; margin: 0 auto 50px; font-weight: 300;
}

/* ============================================================
   SEARCH
   ============================================================ */
.search-shell { max-width: 640px; margin: 0 auto; }
.search-bar {
  display: flex; align-items: center;
  border: 1px solid var(--ink); border-radius: 3px; overflow: hidden;
  background: #fff; box-shadow: 0 18px 50px -32px rgba(26,26,26,0.5);
}
.search-bar input {
  flex: 1; border: none; outline: none; background: transparent;
  font-family: var(--serif); font-size: 22px; font-weight: 300;
  padding: 20px 26px; color: var(--ink); letter-spacing: 0.01em;
}
.search-bar input::placeholder { color: var(--ink-faint); font-style: italic; }
.search-bar button {
  border: none; background: var(--emerald); color: var(--bone);
  font-family: var(--sans); font-size: 13px; letter-spacing: 0.14em;
  text-transform: uppercase; padding: 0 34px; align-self: stretch;
  cursor: pointer; transition: background .3s var(--ease); white-space: nowrap;
}
.search-bar button:hover { background: var(--emerald-soft); }
.search-bar.loading button { opacity: 0.7; cursor: not-allowed; }

.controls { margin-top: 26px; }
.preset-row { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; margin-bottom: 22px; }
.chip {
  font-size: 12px; letter-spacing: 0.05em; padding: 8px 16px;
  border: 1px solid var(--line); border-radius: 40px; cursor: pointer;
  color: var(--ink-soft); background: transparent;
  transition: all .25s var(--ease); text-transform: uppercase;
}
.chip:hover { border-color: var(--ink); color: var(--ink); }
.chip.active { background: var(--ink); color: var(--bone); border-color: var(--ink); }

.sources {
  display: flex; flex-wrap: wrap; gap: 8px 10px; justify-content: center;
  max-width: 580px; margin: 0 auto;
}
.src {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 12.5px; color: var(--ink-soft); cursor: pointer;
  padding: 6px 12px; border-radius: 3px; user-select: none;
  transition: background .2s var(--ease);
}
.src:hover { background: var(--bone-2); }
.src .box {
  width: 14px; height: 14px; border: 1px solid var(--ink-faint);
  border-radius: 2px; display: inline-flex; align-items: center;
  justify-content: center; flex-shrink: 0; transition: all .2s var(--ease);
}
.src.on .box { background: var(--emerald); border-color: var(--emerald); }
.src.on .box::after { content: "✓"; color: var(--bone); font-size: 9px; line-height: 1; }
.src.on { color: var(--ink); }
.country-note {
  text-align: center; font-size: 12px; color: var(--ink-faint);
  margin-top: 18px; letter-spacing: 0.03em;
}
.country-note strong { color: var(--ink-soft); font-weight: 500; }

/* ============================================================
   LOADING STATE
   ============================================================ */
.checking-state { text-align: center; padding: 80px 0; display: none; }
.checking-state.visible { display: block; }
.pulse-ring {
  width: 56px; height: 56px; border-radius: 50%;
  border: 1px solid var(--emerald); margin: 0 auto 28px;
  animation: pulse-ring 1.6s var(--ease) infinite;
}
@keyframes pulse-ring {
  0%   { transform: scale(0.8); opacity: 0.6; }
  50%  { transform: scale(1.1); opacity: 1; }
  100% { transform: scale(0.8); opacity: 0.6; }
}
.checking-label {
  font-family: var(--serif); font-size: 18px; font-weight: 300;
  color: var(--ink-soft); margin-bottom: 10px;
}
.checking-source { font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-faint); }

/* ============================================================
   ELIMINATION REVEAL
   ============================================================ */
.reveal {
  text-align: center; padding: 88px 0 30px;
  border-top: 1px solid var(--line-soft); margin-top: 92px;
}
.reveal .stat-num {
  font-family: var(--serif); font-weight: 300;
  font-size: clamp(54px, 11vw, 132px); line-height: 1; letter-spacing: -0.02em;
}
.reveal .stat-label {
  font-size: 12px; letter-spacing: 0.3em; text-transform: uppercase;
  color: var(--ink-faint); margin-top: 18px;
}
.reveal-grid {
  display: flex; justify-content: center; gap: 70px;
  margin-top: 50px; flex-wrap: wrap;
}
.mini-stat .v { font-family: var(--serif); font-size: 34px; font-weight: 300; color: var(--emerald); }
.mini-stat .k { font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-faint); margin-top: 6px; }

/* ============================================================
   SCORECARD
   ============================================================ */
section.results { padding: 30px 0 110px; }

.scorecard {
  background: #fff; border: 1px solid var(--line); border-radius: 4px;
  max-width: 760px; margin: 0 auto;
  box-shadow: 0 40px 80px -60px rgba(26,26,26,0.55);
  opacity: 0; transform: translateY(24px);
  transition: opacity .6s var(--ease), transform .6s var(--ease);
}
.scorecard.visible { opacity: 1; transform: translateY(0); }
.sc-head {
  display: flex; align-items: flex-start; justify-content: space-between;
  padding: 40px 46px 30px; border-bottom: 1px solid var(--line-soft);
}
.sc-name { font-family: var(--serif); font-size: 46px; font-weight: 400; letter-spacing: -0.01em; }
.sc-tag { font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-faint); margin-top: 6px; }
.sc-score { text-align: right; }
.sc-score .pct { font-family: var(--serif); font-size: 50px; font-weight: 300; color: var(--emerald); line-height: 1; }
.sc-score .pct-label { font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-faint); margin-top: 4px; }

.sc-rows { padding: 14px 46px 30px; }
.row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 17px 0; border-bottom: 1px solid var(--line-soft);
}
.row:last-child { border-bottom: none; }
.row .label { display: flex; align-items: center; gap: 14px; }
.row .label .cat {
  font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink-faint); width: 130px; flex-shrink: 0;
}
.row .label .detail { font-size: 14.5px; color: var(--ink-soft); }
.row .label .detail b { color: var(--ink); font-weight: 500; }

.status { display: inline-flex; align-items: center; gap: 8px; font-size: 12px; letter-spacing: 0.04em; white-space: nowrap; }
.dot { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
.ok .dot  { background: var(--green); }  .ok  { color: var(--green); }
.warn .dot{ background: var(--amber); } .warn{ color: var(--amber); }
.no .dot  { background: var(--red); }   .no  { color: var(--red); }
.dim .dot { background: #aaa; }         .dim { color: #aaa; }

.reg-link {
  font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--emerald); text-decoration: none;
  border-bottom: 1px solid var(--line); padding-bottom: 2px; margin-left: 18px;
  transition: border-color .2s var(--ease);
}
.reg-link:hover { border-color: var(--emerald); }

/* group headers inside scorecard */
.sc-group-head {
  font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-faint); padding: 20px 46px 6px; background: var(--bone-2);
}
.sc-group-head:first-child { padding-top: 14px; }

/* affiliate strip */
.affiliate {
  padding: 26px 46px; background: var(--bone-2);
  display: flex; align-items: center; justify-content: space-between;
  border-top: 1px solid var(--line-soft); flex-wrap: wrap; gap: 16px;
}
.affiliate .a-txt { font-size: 13px; color: var(--ink-soft); }
.affiliate .a-txt b { color: var(--ink); font-weight: 500; }
.reg-btns { display: flex; gap: 10px; flex-wrap: wrap; }
.reg-btn {
  font-size: 12px; letter-spacing: 0.06em; text-decoration: none;
  padding: 10px 18px; border: 1px solid var(--ink); border-radius: 2px;
  color: var(--ink); transition: all .25s var(--ease); background: transparent; white-space: nowrap;
}
.reg-btn.primary { background: var(--emerald); color: var(--bone); border-color: var(--emerald); }
.reg-btn:hover { background: var(--ink); color: var(--bone); border-color: var(--ink); }
.reg-btn.primary:hover { background: var(--emerald-soft); border-color: var(--emerald-soft); }
.a-disc { font-size: 10.5px; color: var(--ink-faint); letter-spacing: 0.03em; width: 100%; }

/* upgrade nudge inside scorecard */
.sc-upgrade {
  padding: 28px 46px; text-align: center; border-top: 1px solid var(--line-soft);
}
.sc-upgrade p { font-size: 13.5px; color: var(--ink-soft); margin-bottom: 14px; }
.btn { display: inline-block; text-decoration: none; }
.btn-emerald {
  background: var(--emerald); color: var(--bone); padding: 13px 30px;
  border-radius: 2px; font-size: 13px; letter-spacing: 0.1em; text-transform: uppercase;
  transition: background .25s var(--ease);
}
.btn-emerald:hover { background: var(--emerald-soft); }
.btn-outline {
  border: 1px solid var(--ink); color: var(--ink); padding: 12px 28px;
  border-radius: 2px; font-size: 13px; letter-spacing: 0.1em; text-transform: uppercase;
  transition: all .25s var(--ease);
}
.btn-outline:hover { background: var(--ink); color: var(--bone); }

/* ============================================================
   ALTERNATIVES
   ============================================================ */
.alts { padding: 0 0 110px; }
.alt-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; max-width: 880px; margin: 0 auto; }
.alt-card {
  background: #fff; border: 1px solid var(--line); border-radius: 4px;
  padding: 30px 28px; cursor: pointer;
  transition: transform .35s var(--ease), box-shadow .35s var(--ease);
}
.alt-card:hover { transform: translateY(-4px); box-shadow: 0 30px 60px -45px rgba(26,26,26,0.5); }
.alt-card .an { font-family: var(--serif); font-size: 28px; font-weight: 400; }
.alt-card .as { font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--green); margin-top: 8px; }
.alt-card .as.warn { color: var(--amber); }
.alt-card .ad { font-size: 13px; color: var(--ink-faint); margin-top: 16px; line-height: 1.5; }
.alt-card .alt-domains { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 14px; }
.alt-domain-tag {
  font-size: 11px; padding: 4px 8px; border-radius: 2px;
  background: var(--bone-2); color: var(--ink-soft);
}
.alt-domain-tag.free { color: var(--green); background: rgba(47,107,79,0.08); }
.alt-domain-tag.taken { color: var(--red); background: rgba(138,58,51,0.07); text-decoration: line-through; }

/* ============================================================
   WATCHLIST / ALERTS BAND
   ============================================================ */
.alerts-band {
  background: var(--emerald); color: var(--bone);
  padding: 90px 0; text-align: center;
}
.alerts-band .eyebrow { color: rgba(247,245,240,0.55); }
.alerts-band h2 {
  font-family: var(--serif); font-weight: 300;
  font-size: clamp(28px, 4.4vw, 50px); max-width: 18ch;
  margin: 18px auto 22px; line-height: 1.1;
}
.alerts-band h2 em { font-style: italic; color: var(--gold); }
.alerts-band p { color: rgba(247,245,240,0.78); max-width: 50ch; margin: 0 auto 40px; font-size: 16px; }
.alert-form {
  display: flex; max-width: 480px; margin: 0 auto;
  border: 1px solid rgba(247,245,240,0.3); border-radius: 3px; overflow: hidden;
}
.alert-form input {
  flex: 1; border: none; outline: none; background: rgba(247,245,240,0.06);
  color: var(--bone); padding: 17px 22px; font-family: var(--sans); font-size: 15px;
}
.alert-form input::placeholder { color: rgba(247,245,240,0.5); }
.alert-form button {
  border: none; background: var(--gold); color: var(--ink); cursor: pointer;
  font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; padding: 0 30px;
  font-family: var(--sans); white-space: nowrap; transition: background .3s var(--ease);
}
.alert-form button:hover { background: #cda968; }
.alert-types { display: flex; gap: 30px; justify-content: center; margin-top: 36px; flex-wrap: wrap; }
.alert-types span { font-size: 12.5px; color: rgba(247,245,240,0.62); letter-spacing: 0.04em; }
.alert-types span::before { content: "—  "; color: var(--gold); }

/* ============================================================
   PRICING
   ============================================================ */
.pricing { padding: 100px 0; }
.price-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  max-width: 920px; margin: 56px auto 0;
  border: 1px solid var(--line); border-radius: 4px; overflow: hidden;
  background: #fff;
}
.tier { padding: 44px 38px; border-right: 1px solid var(--line-soft); }
.tier:last-child { border-right: none; }
.tier.feature { background: var(--ink); color: var(--bone); }
.tier .t-name { font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-faint); }
.tier.feature .t-name { color: var(--gold); }
.tier .t-price { font-family: var(--serif); font-size: 44px; font-weight: 300; margin: 18px 0 4px; line-height: 1; }
.tier .t-price small { font-size: 15px; color: var(--ink-faint); font-family: var(--sans); }
.tier.feature .t-price small { color: rgba(247,245,240,0.5); }
.tier .t-desc { font-size: 13px; color: var(--ink-soft); min-height: 40px; margin-bottom: 4px; }
.tier.feature .t-desc { color: rgba(247,245,240,0.7); }
.tier ul { list-style: none; margin: 26px 0 30px; }
.tier li { font-size: 13.5px; padding: 9px 0; border-bottom: 1px solid var(--line-soft); color: var(--ink-soft); }
.tier.feature li { border-color: rgba(247,245,240,0.12); color: rgba(247,245,240,0.82); }
.tier li::before { content: "·  "; color: var(--gold); }
.t-btn {
  display: block; text-align: center; text-decoration: none; padding: 13px;
  border: 1px solid var(--ink); border-radius: 2px; color: var(--ink);
  font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase;
  transition: all .25s var(--ease);
}
.tier.feature .t-btn { border-color: var(--gold); background: var(--gold); color: var(--ink); }
.t-btn:hover { background: var(--ink); color: var(--bone); }
.tier.feature .t-btn:hover { background: #cda968; border-color: #cda968; }

/* ============================================================
   CURRENCY POPUP
   ============================================================ */
.currency-popup {
  position: fixed; bottom: 28px; left: 50%; transform: translateX(-50%) translateY(20px);
  background: #fff; border: 1px solid var(--line); border-radius: 4px;
  padding: 18px 22px; box-shadow: 0 20px 60px -20px rgba(26,26,26,0.35);
  display: flex; align-items: center; gap: 18px; z-index: 999;
  opacity: 0; pointer-events: none;
  transition: opacity .4s var(--ease), transform .4s var(--ease);
  white-space: nowrap;
}
.currency-popup.visible { opacity: 1; transform: translateX(-50%) translateY(0); pointer-events: all; }
.cp-text { font-size: 13px; color: var(--ink-soft); }
.cp-text strong { color: var(--ink); font-weight: 500; }
.cp-flags { display: flex; gap: 8px; }
.cp-flag {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12px; letter-spacing: 0.04em; padding: 7px 13px;
  border: 1px solid var(--line); border-radius: 2px; cursor: pointer;
  transition: all .2s var(--ease); color: var(--ink-soft); text-decoration: none;
}
.cp-flag:hover { border-color: var(--ink); color: var(--ink); }
.cp-flag.active { border-color: var(--emerald); color: var(--emerald); background: rgba(15,61,46,0.04); }
.cp-close {
  background: none; border: none; cursor: pointer; color: var(--ink-faint);
  font-size: 18px; line-height: 1; padding: 2px; transition: color .2s;
}
.cp-close:hover { color: var(--ink); }

/* ============================================================
   ACCOUNT / DASHBOARD
   ============================================================ */
.page-header { padding: 70px 0 50px; border-bottom: 1px solid var(--line-soft); }
.page-header .eyebrow { margin-bottom: 12px; }
.page-header h1 { font-family: var(--serif); font-weight: 300; font-size: clamp(28px, 4vw, 42px); letter-spacing: -0.01em; }
.page-header p { color: var(--ink-soft); font-size: 15px; margin-top: 8px; }

.dash-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 1px; background: var(--line-soft); border: 1px solid var(--line-soft); border-radius: 4px; overflow: hidden; margin: 48px 0; }
.dash-stat { background: #fff; padding: 30px 28px; }
.dash-stat .ds-val { font-family: var(--serif); font-size: 38px; font-weight: 300; color: var(--emerald); }
.dash-stat .ds-key { font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-faint); margin-top: 6px; }

.account-sections { padding: 0 0 80px; }
.account-section { padding: 40px 0; border-bottom: 1px solid var(--line-soft); }
.account-section:last-child { border-bottom: none; }
.account-section h3 { font-family: var(--serif); font-size: 22px; font-weight: 300; margin-bottom: 20px; }

/* Recent searches table */
.data-table { width: 100%; border-collapse: collapse; font-size: 13.5px; }
.data-table th { text-align: left; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-faint); padding: 0 0 12px; border-bottom: 1px solid var(--line); font-weight: 400; }
.data-table td { padding: 14px 0; border-bottom: 1px solid var(--line-soft); color: var(--ink-soft); vertical-align: middle; }
.data-table td:first-child { color: var(--ink); font-weight: 400; }
.data-table tr:last-child td { border-bottom: none; }
.score-pill { display: inline-block; padding: 3px 10px; border-radius: 20px; font-size: 11px; letter-spacing: 0.06em; }
.score-pill.high { background: rgba(47,107,79,0.1); color: var(--green); }
.score-pill.mid  { background: rgba(154,123,46,0.1); color: var(--amber); }
.score-pill.low  { background: rgba(138,58,51,0.08); color: var(--red); }

/* ============================================================
   WATCHLIST PAGE
   ============================================================ */
.watchlist-grid { display: grid; gap: 1px; background: var(--line-soft); border: 1px solid var(--line-soft); border-radius: 4px; overflow: hidden; }
.wl-item { background: #fff; padding: 22px 28px; display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.wl-item:hover { background: var(--bone); }
.wl-name { font-family: var(--serif); font-size: 20px; font-weight: 400; }
.wl-meta { font-size: 12px; color: var(--ink-faint); margin-top: 4px; letter-spacing: 0.03em; }
.wl-type {
  font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase;
  padding: 5px 10px; border-radius: 2px; background: var(--bone-2); color: var(--ink-soft);
}
.wl-remove { background: none; border: none; color: var(--ink-faint); font-size: 18px; cursor: pointer; padding: 4px; transition: color .2s; }
.wl-remove:hover { color: var(--red); }
.wl-add-form { margin-top: 32px; display: flex; gap: 12px; align-items: flex-end; flex-wrap: wrap; }
.form-group { display: flex; flex-direction: column; gap: 6px; }
.form-group label { font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-faint); }
.form-group input, .form-group select {
  border: 1px solid var(--line); border-radius: 2px; padding: 11px 14px;
  font-family: var(--sans); font-size: 14px; background: #fff; color: var(--ink);
  outline: none; transition: border-color .2s;
}
.form-group input:focus, .form-group select:focus { border-color: var(--emerald); }

/* ============================================================
   EXPIRING DOMAINS PAGE
   ============================================================ */
.expiring-filters { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; margin-bottom: 32px; }
.expiring-filters input[type="text"] {
  flex: 1; min-width: 200px; border: 1px solid var(--line); border-radius: 2px;
  padding: 10px 14px; font-size: 14px; font-family: var(--sans); outline: none;
  transition: border-color .2s;
}
.expiring-filters input[type="text"]:focus { border-color: var(--emerald); }
.expiring-table { width: 100%; border-collapse: collapse; font-size: 13.5px; }
.expiring-table th { text-align: left; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-faint); padding: 0 16px 12px; border-bottom: 1px solid var(--line); font-weight: 400; }
.expiring-table th:first-child { padding-left: 0; }
.expiring-table td { padding: 14px 16px; border-bottom: 1px solid var(--line-soft); color: var(--ink-soft); }
.expiring-table td:first-child { padding-left: 0; color: var(--ink); font-weight: 400; font-family: var(--serif); font-size: 15px; }
.expiring-table tr:last-child td { border-bottom: none; }
.tld-tag { font-size: 11px; padding: 3px 7px; background: var(--bone-2); border-radius: 2px; color: var(--ink-soft); }
.status-tag { font-size: 11px; padding: 3px 8px; border-radius: 2px; letter-spacing: 0.04em; }
.status-tag.expiring       { background: rgba(154,123,46,0.1); color: var(--amber); }
.status-tag.pending_delete { background: rgba(138,58,51,0.08); color: var(--red); }
.status-tag.available      { background: rgba(47,107,79,0.1); color: var(--green); }

/* ============================================================
   GUIDES
   ============================================================ */
.guides-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.guide-card {
  background: #fff; border: 1px solid var(--line); border-radius: 4px;
  padding: 32px 28px; text-decoration: none; display: block;
  transition: transform .3s var(--ease), box-shadow .3s var(--ease);
}
.guide-card:hover { transform: translateY(-3px); box-shadow: 0 20px 50px -35px rgba(26,26,26,0.4); }
.guide-card .gc-cat { font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--gold); margin-bottom: 12px; }
.guide-card .gc-title { font-family: var(--serif); font-size: 20px; font-weight: 300; line-height: 1.3; margin-bottom: 12px; color: var(--ink); }
.guide-card .gc-lede { font-size: 13px; color: var(--ink-faint); line-height: 1.6; }

/* ============================================================
   AUTH PAGES (login / register)
   ============================================================ */
.auth-wrap { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: 40px 20px; }
.auth-box { background: #fff; border: 1px solid var(--line); border-radius: 4px; padding: 48px 44px; width: 100%; max-width: 420px; }
.auth-box .wordmark { display: block; text-align: center; margin-bottom: 36px; }
.auth-box h1 { font-family: var(--serif); font-size: 28px; font-weight: 300; margin-bottom: 8px; }
.auth-box p { font-size: 14px; color: var(--ink-faint); margin-bottom: 28px; }
.auth-form { display: flex; flex-direction: column; gap: 16px; }
.auth-form label { font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-faint); display: block; margin-bottom: 6px; }
.auth-form input {
  width: 100%; padding: 13px 15px; border: 1px solid var(--line); border-radius: 2px;
  font-family: var(--sans); font-size: 15px; color: var(--ink);
  background: var(--bone); outline: none; transition: border-color .2s;
}
.auth-form input:focus { border-color: var(--emerald); background: #fff; }
.auth-form button[type="submit"] {
  width: 100%; padding: 14px; background: var(--emerald); color: var(--bone);
  border: none; border-radius: 2px; font-family: var(--sans); font-size: 13px;
  letter-spacing: 0.12em; text-transform: uppercase; cursor: pointer;
  transition: background .25s var(--ease); margin-top: 4px;
}
.auth-form button[type="submit"]:hover { background: var(--emerald-soft); }
.auth-footer-link { text-align: center; font-size: 13px; color: var(--ink-faint); margin-top: 20px; }
.auth-footer-link a { color: var(--emerald); text-decoration: none; }
.flash { padding: 12px 16px; border-radius: 2px; font-size: 13.5px; margin-bottom: 8px; }
.flash.error { background: rgba(138,58,51,0.08); color: var(--red); }
.flash.success { background: rgba(47,107,79,0.08); color: var(--green); }

/* ============================================================
   404
   ============================================================ */
.page-404 { text-align: center; padding: 120px 20px; }
.page-404 .num { font-family: var(--serif); font-size: clamp(80px, 18vw, 180px); font-weight: 300; line-height: 1; color: var(--bone-2); }
.page-404 h1 { font-family: var(--serif); font-size: 28px; font-weight: 300; margin: -20px 0 16px; }
.page-404 p { color: var(--ink-soft); margin-bottom: 32px; }

/* ============================================================
   AFFILIATE BANNERS
   ============================================================ */
.banner-slot { text-align: center; margin: 40px 0; }
.banner-slot img { max-width: 100%; height: auto; display: inline-block; border-radius: 2px; }

/* ============================================================
   FOOTER
   ============================================================ */
footer {
  border-top: 1px solid var(--line-soft);
  padding: 60px 0 80px; text-align: center;
}
footer .fmark { font-family: var(--serif); font-size: 18px; letter-spacing: 0.16em; text-transform: uppercase; }
footer .fmark span { color: var(--gold); }
footer p { font-size: 12px; color: var(--ink-faint); margin-top: 16px; letter-spacing: 0.03em; }
.footer-links { display: flex; justify-content: center; gap: 30px; margin-top: 24px; }
.footer-links a { font-size: 12px; color: var(--ink-faint); text-decoration: none; letter-spacing: 0.04em; transition: color .2s; }
.footer-links a:hover { color: var(--ink-soft); }

/* ============================================================
   FREE TIER LIMIT BANNER
   ============================================================ */
.limit-banner {
  background: var(--bone-2); border: 1px solid var(--line); border-radius: 3px;
  padding: 14px 22px; display: flex; align-items: center; justify-content: space-between;
  gap: 14px; font-size: 13px; color: var(--ink-soft); max-width: 640px; margin: 16px auto 0;
  flex-wrap: wrap;
}
.limit-banner a { color: var(--emerald); text-decoration: none; font-weight: 500; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 820px) {
  .wrap { padding: 0 20px; }
  nav { padding: 22px 20px; }
  .nav-links a:not(.nav-cta) { display: none; }
  .nav-mobile-btn { display: flex; }
  .hero { padding: 70px 0 30px; }
  .alt-grid { grid-template-columns: 1fr; }
  .price-grid { grid-template-columns: 1fr; }
  .tier { border-right: none; border-bottom: 1px solid var(--line-soft); }
  .tier:last-child { border-bottom: none; }
  .search-bar { flex-direction: column; align-items: stretch; }
  .search-bar input { text-align: center; }
  .search-bar button { padding: 16px; }
  .sc-head { flex-direction: column; gap: 18px; }
  .sc-score { text-align: left; }
  .sc-rows { padding: 14px 20px 20px; }
  .sc-head { padding: 28px 20px 20px; }
  .affiliate { padding: 20px; }
  .sc-group-head { padding-left: 20px; padding-right: 20px; }
  .sc-upgrade { padding: 20px; }
  .row { flex-direction: column; align-items: flex-start; gap: 10px; }
  .row .label { flex-direction: column; align-items: flex-start; gap: 4px; }
  .row .label .cat { width: auto; }
  .reveal-grid { gap: 36px; }
  .dash-grid { grid-template-columns: 1fr 1fr; }
  .guides-grid { grid-template-columns: 1fr; }
  .auth-box { padding: 32px 24px; }
  .currency-popup { width: calc(100% - 32px); flex-wrap: wrap; gap: 12px; }
}

@media (max-width: 540px) {
  .dash-grid { grid-template-columns: 1fr; }
  .wl-item { flex-wrap: wrap; }
  .expiring-filters { flex-direction: column; align-items: stretch; }
}
