@import url("colors_and_type.css");

/* shared kit primitives ------------------------------------- */
html, body { margin: 0; background: var(--canvas); color: var(--fg); font-family: var(--font-body); }
* { box-sizing: border-box; }
.container { width: 100%; max-width: 1240px; margin: 0 auto; padding: 0 32px; }
.eyebrow { font: var(--t-eyebrow); letter-spacing: 0.14em; text-transform: uppercase; color: var(--fg-muted); }

/* dot helper */
.dot { display: inline-block; width: 0.55em; height: 0.55em; border-radius: 999px; background: var(--orange-500); transform: translateY(-0.05em); margin-left: 0.03em; }

/* btn */
.btn {
  height: 40px; padding: 0 18px; border-radius: 10px; border: 1px solid transparent;
  background: var(--orange-500); color: #FFFFFF;
  font: 500 14px/1 var(--font-body);
  display: inline-flex; align-items: center; gap: 8px;
  cursor: pointer; transition: background 140ms var(--ease-out), transform 140ms var(--ease-out);
}
.btn:hover { background: var(--orange-600); }
.btn:active { background: var(--orange-700); transform: scale(0.98); }
.btn.lg { height: 48px; padding: 0 22px; font-size: 15px; border-radius: 12px; }
.btn.secondary { background: #FFFFFF; color: var(--fg); border-color: var(--ink-200); }
.btn.secondary:hover { background: var(--surface-2); border-color: var(--ink-300); }
.btn.ghost { background: transparent; color: var(--fg); }
.btn.ghost:hover { background: var(--ink-100); }
.btn svg { width: 16px; height: 16px; stroke-width: 1.75; }

/* ---- Header --------------------------------------------- */
.hd {
  position: sticky; top: 16px; z-index: 50; margin-top: 16px;
}
.hd-inner {
  background: rgba(245, 245, 245, 0.72);
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  border: 1px solid rgba(0,0,0,0.06);
  border-radius: 999px;
  padding: 8px 8px 8px 22px;
  display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 24px;
}
.hd .wm { font: 700 22px/1 var(--font-display); letter-spacing: -0.04em; color: var(--fg); display: inline-flex; align-items: baseline; }
.hd .wm .dot { width: 7px; height: 7px; margin-left: -1px; transform: translateY(-1px); }
.hd nav { display: flex; gap: 4px; justify-content: center; }
.hd nav a {
  padding: 8px 14px; border-radius: 999px;
  font: 500 13px/1 var(--font-body); color: var(--ink-600); text-decoration: none;
}
.hd nav a.active { background: var(--fg); color: #FFFFFF; }
.hd nav a:hover:not(.active) { color: var(--fg); }
.hd .right { display: flex; gap: 8px; align-items: center; }

/* ---- Hero ----------------------------------------------- */
.hero { padding: 64px 0 96px; }
.hero h1 {
  margin: 18px 0 18px; font: 600 88px/0.96 var(--font-display);
  letter-spacing: -0.045em; max-width: 14ch;
}
.hero h1 .swap { color: var(--orange-500); }
.hero .lead {
  font: var(--t-lead); max-width: 56ch;
  color: var(--ink-700); margin-bottom: 32px;
}
.hero .cta-row { display: flex; gap: 12px; }

.gapviz {
  margin-top: 64px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 28px;
  padding: 28px;
  display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 24px;
}
.gapviz .col { display: flex; flex-direction: column; gap: 6px; }
.gapviz .col .label { font: var(--t-eyebrow); letter-spacing: 0.14em; text-transform: uppercase; color: var(--fg-muted); }
.gapviz .col .word { font: 600 28px/1 var(--font-display); letter-spacing: -0.02em; }
.gapviz .bridge { display: flex; align-items: center; gap: 6px; font: 500 13px/1 var(--font-mono); color: var(--orange-500); }
.gapviz .bridge .line { width: 64px; height: 2px; background: var(--orange-500); }
.gapviz .bridge svg { width: 18px; height: 18px; color: var(--orange-500); }

/* ---- Services ------------------------------------------- */
.section { padding: 96px 0; }
.section-head { display: grid; grid-template-columns: 1fr auto; align-items: end; gap: 24px; margin-bottom: 40px; }
.section-head h2 { margin: 8px 0 0; font: 600 44px/1.08 var(--font-display); letter-spacing: -0.025em; max-width: 18ch; }
.section-head .right { font: var(--t-body); color: var(--ink-600); max-width: 38ch; }

.svc-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 16px; }
.svc {
  background: var(--surface); border: 1px solid var(--border); border-radius: 20px;
  padding: 28px; display: flex; flex-direction: column; gap: 14px; min-height: 320px;
  transition: border-color 220ms var(--ease-out), box-shadow 220ms var(--ease-out);
}
.svc:hover { border-color: var(--border-strong); box-shadow: var(--shadow-sm); }
.svc .ic { width: 40px; height: 40px; border-radius: 10px; background: var(--orange-50); color: var(--orange-700); display: grid; place-items: center; }
.svc .ic svg { width: 22px; height: 22px; stroke-width: 1.75; }
.svc h3 { margin: 4px 0 0; font: 600 22px/1.2 var(--font-display); letter-spacing: -0.015em; }
.svc p { margin: 0; color: var(--ink-600); font: var(--t-body-sm); }
.svc ul { margin: auto 0 0; padding: 0; list-style: none; display: flex; flex-direction: column; gap: 8px; }
.svc ul li { display: grid; grid-template-columns: 18px 1fr; gap: 8px; font: var(--t-body-sm); align-items: center; }
.svc ul li svg { width: 14px; height: 14px; color: var(--orange-500); stroke-width: 2; }

/* ---- Brands strip --------------------------------------- */
.brands { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.brand-tile {
  border-radius: 24px; padding: 32px;
  display: grid; grid-template-rows: auto 1fr auto;
  gap: 20px; min-height: 360px;
  position: relative; overflow: hidden;
  text-decoration: none;
}
.brand-tile .row1 { display: flex; align-items: center; justify-content: space-between; }
.brand-tile .name { font: 700 36px/1 var(--font-display); letter-spacing: -0.025em; }
.brand-tile .badge { font: 500 11px/1 var(--font-body); padding: 5px 10px; border-radius: 999px; text-transform: uppercase; letter-spacing: 0.1em; }
.brand-tile p { margin: 0; max-width: 32ch; font: var(--t-body); }
.brand-tile .meta { display: flex; gap: 24px; font: var(--t-mono); font-size: 12px; }
.brand-tile .meta .num { font: 600 22px/1 var(--font-display); letter-spacing: -0.02em; display: block; margin-bottom: 2px; color: inherit; }
.brand-tile .meta .lbl { color: inherit; opacity: 0.6; }

.brand-tile.snooze { background: #F4ECDE; color: #2E2A23; }
.brand-tile.snooze .badge { background: #7E9171; color: #FFFFFF; }
.brand-tile.nousu  { background: #FFFFFF; color: #131313; border: 1px solid var(--border); }
.brand-tile.nousu  .badge { background: #FF6F5C; color: #FFFFFF; }
.brand-tile.nousu  .meta .lbl { color: #6B6B6B; opacity: 1; }

.brand-tile .glyph { position: absolute; right: 24px; bottom: 24px; width: 84px; height: 84px; opacity: 0.85; }

/* ---- Stats strip ---------------------------------------- */
.stats {
  background: var(--ink-900); color: #F2F2F2;
  border-radius: 28px; padding: 56px 48px;
  display: grid; grid-template-columns: 1.4fr repeat(3, 1fr); gap: 32px;
  align-items: end;
}
.stats h2 { margin: 0; font: 600 36px/1.1 var(--font-display); letter-spacing: -0.025em; color: #FFFFFF; max-width: 16ch; }
.stats .stat .label { font: var(--t-eyebrow); color: #8E8E8E; letter-spacing: 0.14em; text-transform: uppercase; }
.stats .stat .v { font: 600 56px/1 var(--font-display); letter-spacing: -0.035em; color: #FFFFFF; margin-top: 8px; font-variant-numeric: tabular-nums; }
.stats .stat .v .u { font: 500 22px/1 var(--font-body); color: #B5B5B5; margin-left: 4px; }
.stats .stat .sub { display: block; margin-top: 6px; font: var(--t-body-sm); color: #B5B5B5; }

/* ---- Contact -------------------------------------------- */
.contact { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; background: var(--surface); border: 1px solid var(--border); border-radius: 28px; padding: 48px; }
.contact h2 { margin: 0 0 16px; font: 600 40px/1.05 var(--font-display); letter-spacing: -0.025em; }
.contact p  { margin: 0 0 24px; font: var(--t-body); color: var(--ink-600); }
.contact .meta { display: flex; flex-direction: column; gap: 14px; margin-top: 16px; }
.contact .meta .row { display: grid; grid-template-columns: 28px 1fr; align-items: center; gap: 10px; font: var(--t-body-sm); color: var(--ink-700); }
.contact .meta .row svg { width: 16px; height: 16px; color: var(--orange-500); stroke-width: 1.75; }

.contact form { display: flex; flex-direction: column; gap: 12px; }
.contact form .grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.contact label { font: 500 12px/1 var(--font-body); color: var(--fg); }
.contact .field { display: flex; flex-direction: column; gap: 5px; }
.contact .input { height: 42px; border-radius: 8px; background: var(--canvas); border: 1px solid var(--ink-200); padding: 0 12px; font: 14px/1 var(--font-body); color: var(--fg); }
.contact .input:focus { outline: 0; border-color: var(--orange-500); box-shadow: 0 0 0 3px rgba(236,95,44,0.18); background: #FFFFFF; }
.contact textarea.input { height: 96px; padding: 12px; resize: none; }

/* ---- Footer --------------------------------------------- */
.ft { padding: 64px 0 48px; }
.ft-inner { background: var(--ink-900); color: #F2F2F2; border-radius: 28px; padding: 56px 48px; display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 32px; }
.ft .wm { font: 700 36px/1 var(--font-display); letter-spacing: -0.04em; color: #FFFFFF; display: inline-flex; align-items: baseline; }
.ft .wm .dot { width: 12px; height: 12px; margin-left: -2px; transform: translateY(-2px); }
.ft .blurb { color: #8E8E8E; font: var(--t-body-sm); margin: 16px 0 0; max-width: 32ch; }
.ft .col h4 { font: var(--t-eyebrow); letter-spacing: 0.14em; text-transform: uppercase; color: #8E8E8E; margin: 0 0 14px; }
.ft .col ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; font: var(--t-body-sm); }
.ft .col a { color: #ECECEC; text-decoration: none; }
.ft .col a:hover { color: var(--orange-400); }
.ft-base { display: flex; justify-content: space-between; padding-top: 32px; margin-top: 32px; border-top: 1px solid #2A2A2A; color: #8E8E8E; font: var(--t-mono); font-size: 12px; }
