/* =================================================================
   ADKICKS — Editorial Redesign
   Aesthetic: refined editorial agency. Cream paper × near-black ink
   × single ultramarine accent. Big confident type, hairline rules,
   generous negative space. No gradients, no orbs.
   ================================================================= */

*{margin:0;padding:0;box-sizing:border-box;}

:root{
  --paper:#F3F4F8;       /* cool clean off-white */
  --paper-2:#E9EBF2;     /* slightly deeper panel */
  --surface:#FFFFFF;     /* card / surface white */
  --ink:#0D0F18;         /* cool near-black */
  --ink-2:#34384a;       /* secondary text on light */
  --sub:#6c7082;         /* muted body text */
  --line:#d7d9e4;        /* hairline on paper */
  --line-soft:#e4e6ee;
  --blue:#2A45E6;        /* brand royal blue */
  --blue-deep:#1c30b4;
  --purple:#7A36C6;      /* brand mid purple */
  --hot:#EC1A7B;         /* brand magenta accent */
  --grad:linear-gradient(100deg,#2A45E6 0%,#7A36C6 52%,#EC1A7B 100%);
  --ink-line:rgba(255,255,255,.12); /* hairline on dark */

  --ff-disp:'Archivo',sans-serif;
  --ff-jp:'Zen Kaku Gothic New',sans-serif;
  --ff-mincho:'Zen Old Mincho',serif;

  --pad:clamp(20px,5vw,88px);
  --maxw:1120px;
  --gutter:max(var(--pad), calc((100% - var(--maxw)) / 2));
}
.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;}

html{scroll-behavior:smooth;}
body{
  font-family:var(--ff-jp);
  background:var(--paper);
  color:var(--ink);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
::selection{background:var(--blue);color:#fff;}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}

/* ---------- TYPE HELPERS ---------- */
.eyebrow{
  font-family:var(--ff-disp);
  font-size:11px;font-weight:600;
  letter-spacing:.32em;text-transform:uppercase;
  color:var(--blue);
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{
  content:'';width:22px;height:1px;background:var(--blue);display:inline-block;
}
.eyebrow.center{justify-content:center;}
.mincho{font-family:var(--ff-mincho);font-weight:700;letter-spacing:.02em;}
.display{font-family:var(--ff-disp);font-weight:800;letter-spacing:-.02em;line-height:.9;}

.s-title{
  font-family:var(--ff-jp);
  font-weight:700;
  font-size:clamp(28px,4.2vw,54px);
  line-height:1.14;
  letter-spacing:-.01em;
  margin-top:22px;
}
.s-lead{
  font-size:15px;line-height:2;color:var(--sub);font-weight:400;
  max-width:48ch;
}

section{padding:clamp(72px,10vw,140px) var(--gutter);position:relative;}
.rule{height:1px;background:var(--line);border:0;}

/* ===================================================================
   NAV
   =================================================================== */
header.nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px var(--gutter);
  transition:padding .35s,background .35s,border-color .35s;
  border-bottom:1px solid transparent;
}
header.nav.sc{
  background:rgba(241,239,232,.82);
  backdrop-filter:blur(16px) saturate(1.2);
  border-bottom:1px solid var(--line);
  padding:14px var(--gutter);
}
.brand{display:inline-flex;align-items:center;}
.brand img{height:26px;width:auto;display:block;transition:height .35s;}
header.nav.sc .brand img{height:23px;}
.nav-links{display:flex;gap:30px;align-items:center;}
.nav-links a{
  font-size:13px;font-weight:500;color:var(--ink-2);
  position:relative;padding:2px 0;transition:color .2s;
}
.nav-links a::after{
  content:'';position:absolute;left:0;right:0;bottom:-3px;height:1px;
  background:var(--ink);transform:scaleX(0);transform-origin:left;
  transition:transform .3s;
}
.nav-links a:hover{color:var(--ink);}
.nav-links a:hover::after{transform:scaleX(1);}
.nav-cta{
  font-family:var(--ff-disp);font-size:12px;font-weight:600;
  letter-spacing:.04em;text-transform:uppercase;
  background:var(--grad);color:#fff;
  padding:11px 22px;border-radius:100px;transition:.25s;
  box-shadow:0 6px 18px -8px rgba(42,69,230,.6);
}
.nav-cta:hover{filter:brightness(1.08);box-shadow:0 8px 22px -8px rgba(236,26,123,.55);}
.nav-right{display:flex;align-items:center;gap:26px;}
.hamburger{display:none;}
.mobile-menu{display:none;}

/* ===================================================================
   HERO
   =================================================================== */
#hero{
  min-height:100vh;display:flex;align-items:center;
  padding-top:clamp(108px,15vh,150px);padding-bottom:clamp(48px,7vh,72px);
  overflow:hidden;
}
.hero-inner{
  display:grid;width:100%;
  grid-template-columns:minmax(0,1fr) clamp(300px,33%,420px);
  gap:clamp(36px,4vw,64px);align-items:center;
}
.hero-left{display:flex;flex-direction:column;justify-content:center;}
.hero-right{
  position:relative;align-self:center;
  display:flex;align-items:center;justify-content:flex-end;
  margin-right:calc(-1 * var(--gutter));
}
.hv-illu{display:block;width:100%;max-width:510px;height:auto;
  -webkit-mask-image:linear-gradient(to right,transparent 0,#000 4%,#000 96%,transparent 100%),linear-gradient(to bottom,transparent 0,#000 3%,#000 97%,transparent 100%);
  -webkit-mask-composite:source-in;mask-composite:intersect;
  mask-image:linear-gradient(to right,transparent 0,#000 4%,#000 96%,transparent 100%),linear-gradient(to bottom,transparent 0,#000 3%,#000 97%,transparent 100%);}
.hero-top{display:flex;align-items:center;gap:14px;margin-bottom:clamp(22px,3.5vh,40px);}
.hero-tag{
  font-family:var(--ff-disp);font-size:11px;font-weight:600;
  letter-spacing:.28em;text-transform:uppercase;color:var(--ink-2);
}
.hero-dot{width:7px;height:7px;border-radius:50%;background:var(--hot);
  box-shadow:0 0 0 0 rgba(236,26,123,.5);animation:pulse 2.4s infinite;}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(236,26,123,.45);}
  70%{box-shadow:0 0 0 9px rgba(236,26,123,0);}
  100%{box-shadow:0 0 0 0 rgba(236,26,123,0);}
}

.hero-h{
  font-family:var(--ff-jp);font-weight:700;
  font-size:clamp(38px,5.4vw,72px);
  line-height:1.1;letter-spacing:-.02em;
  word-break:keep-all;
}
.hero-h .li{display:block;}
.hero-h .li > span{display:block;}
@keyframes rise{to{transform:translateY(0);}}
.hero-h em{
  font-family:inherit;font-style:normal;font-weight:inherit;
  font-size:1em;letter-spacing:inherit;
  background:linear-gradient(100deg,#2A45E6 0%,#9B1FD4 48%,#FF0A6C 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;
}

.hero-bottom{
  display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:end;
  margin-top:clamp(36px,6vh,72px);
  padding-top:30px;border-top:1px solid var(--line);
}
.hero-desc{font-size:15px;line-height:2.05;color:var(--ink-2);max-width:52ch;font-weight:400;margin-top:clamp(24px,3.5vh,36px);}
.hero-desc b{color:var(--ink);font-weight:700;}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:26px;}

.btn{
  font-family:var(--ff-disp);font-size:13px;font-weight:600;
  letter-spacing:.02em;
  display:inline-flex;align-items:center;gap:9px;
  padding:14px 26px;border-radius:100px;transition:.25s;cursor:pointer;
}
.btn .ar{transition:transform .25s;}
.btn:hover .ar{transform:translateX(4px);}
.btn-fill{background:var(--ink);color:var(--paper);}
.btn-fill:hover{background:var(--blue);}
.btn-grad{background:var(--grad);color:#fff;box-shadow:0 10px 26px -12px rgba(42,69,230,.65);}
.btn-grad:hover{filter:brightness(1.07);box-shadow:0 12px 30px -12px rgba(236,26,123,.55);}
.btn-line{border:1.4px solid var(--line);color:var(--ink);}
.btn-line:hover{border-color:var(--ink);}

.hero-proof{display:flex;margin-top:clamp(28px,4vh,44px);max-width:680px;
  padding-top:26px;border-top:1px solid var(--line);}
.proof{flex:1;min-width:0;padding:0 clamp(14px,2vw,28px);border-left:1px solid var(--line);}
.proof:first-child{padding-left:0;border-left:none;}
.proof .n{font-family:var(--ff-disp),var(--ff-jp);font-weight:800;
  font-size:clamp(28px,2.9vw,40px);line-height:1;letter-spacing:-.02em;color:var(--ink);white-space:nowrap;}
.proof .n .u{font-size:.5em;font-weight:700;margin-left:2px;color:var(--hot);}
.proof .l{font-size:11.5px;color:var(--sub);margin-top:11px;line-height:1.5;letter-spacing:.01em;}

/* ===================================================================
   MARQUEE
   =================================================================== */
.marquee{
  border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);
  overflow:hidden;background:var(--ink);color:var(--paper);
  padding:16px 0;
}
.marquee .track{display:flex;white-space:nowrap;animation:mq 32s linear infinite;}
.marquee span{
  font-family:var(--ff-disp);font-size:15px;font-weight:600;
  letter-spacing:.12em;text-transform:uppercase;padding:0 26px;display:inline-flex;align-items:center;gap:26px;
}
.marquee .star{color:var(--hot);font-size:13px;}
@keyframes mq{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ===================================================================
   STRENGTHS — editorial numbered list
   =================================================================== */
#strengths{background:var(--paper);}
.sec-head{
  display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:end;
  margin-bottom:clamp(48px,7vw,90px);
}
.sec-head .s-lead{justify-self:end;}
@media(min-width:1025px){
  #strengths .sec-head{grid-template-columns:.78fr 1fr;}
  #strengths .sec-head .s-lead{justify-self:start;max-width:512px;font-size:13.5px;line-height:1.95;}
}

.str-list{border-top:1px solid var(--line);}
.str-row{
  display:grid;grid-template-columns:104px minmax(200px,300px) minmax(0,1fr);gap:clamp(28px,2.6vw,48px);align-items:start;
  padding:clamp(28px,3.4vw,46px) 0;
  border-bottom:1px solid var(--line);
  transition:padding-left .35s;position:relative;
}
.str-row::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:0;
  background:var(--blue);transition:width .35s;
}
.str-row:hover{padding-left:24px;}
.str-row:hover::before{width:3px;}
.str-idx{font-family:var(--ff-disp);font-weight:800;font-size:clamp(30px,3vw,42px);
  letter-spacing:-.03em;color:var(--ink);line-height:1;}
.str-idx .b{display:block;font-size:10px;font-weight:600;letter-spacing:.18em;
  color:var(--blue);margin-top:12px;}
.str-ico{display:block;width:40px;height:40px;margin-top:22px;color:var(--blue);
  opacity:.85;transition:transform .35s,color .35s;}
.str-row:hover .str-ico{transform:translateY(-2px);color:var(--hot);}
.str-row h3{font-size:clamp(20px,2vw,27px);font-weight:700;line-height:1.32;}
.str-row .tag{display:inline-block;font-family:var(--ff-disp);font-size:10px;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;color:var(--hot);margin-bottom:12px;}
.str-row p{font-size:14px;line-height:2;color:var(--sub);max-width:none;}

/* ===================================================================
   PERFORMANCE — dark
   =================================================================== */
#performance{background:var(--ink);color:var(--paper);text-align:center;}
#performance .eyebrow{color:#9b9af0;}
#performance .eyebrow::before{background:#9b9af0;}
.perf-h{font-family:var(--ff-jp);font-weight:700;font-size:clamp(28px,4.4vw,58px);
  line-height:1.16;letter-spacing:-.01em;margin-top:20px;}
.perf-h em{font-family:var(--ff-mincho);font-style:normal;font-weight:700;letter-spacing:.03em;background:linear-gradient(100deg,#8aa0ff,#ff6db5);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;}
.perf-sub{font-size:14px;color:rgba(255,255,255,.5);margin-top:18px;line-height:1.9;}

.perf-grid{
  display:grid;grid-template-columns:1fr auto 1fr;gap:clamp(18px,3vw,40px);
  align-items:stretch;max-width:920px;margin:clamp(44px,6vw,72px) auto 0;
}
.perf-card{
  border:1px solid var(--ink-line);border-radius:18px;
  padding:clamp(30px,4vw,52px) clamp(22px,3vw,40px);text-align:center;
  display:flex;flex-direction:column;align-items:center;
  background:rgba(255,255,255,.02);
}
.perf-card.yes{background:rgba(30,34,220,.22);border-color:rgba(120,124,255,.4);}
.perf-pct{font-family:var(--ff-disp);font-weight:800;font-size:clamp(56px,9vw,104px);
  line-height:.85;letter-spacing:-.04em;}
.perf-pct .u{display:block;font-size:.2em;font-weight:600;letter-spacing:.06em;
  color:rgba(255,255,255,.6);margin-top:14px;}
.perf-card.yes .perf-pct{color:#fff;}
.perf-card.no .perf-pct{color:rgba(255,255,255,.4);}
.perf-eg{font-size:13px;color:rgba(255,255,255,.5);line-height:1.7;margin:20px 0 24px;}
.perf-eg b{color:#fff;font-weight:700;}
.perf-flag{font-family:var(--ff-disp);font-size:12px;font-weight:600;letter-spacing:.04em;
  padding:9px 20px;border-radius:100px;}
.perf-card.yes .perf-flag{background:var(--blue);color:#fff;}
.perf-card.no .perf-flag{border:1px solid var(--ink-line);color:rgba(255,255,255,.55);}
.perf-vs{align-self:center;font-family:var(--ff-disp);font-weight:800;font-size:16px;
  color:rgba(255,255,255,.28);letter-spacing:.1em;}

.perf-merits{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--ink-line);border:1px solid var(--ink-line);border-radius:16px;overflow:hidden;
  max-width:920px;margin:clamp(36px,5vw,56px) auto 0;text-align:left;}
.perf-merit{background:var(--ink);padding:30px 28px;}
.perf-merit .mi{font-family:var(--ff-disp);font-weight:800;font-size:13px;color:#9b9af0;letter-spacing:.1em;margin-bottom:14px;}
.perf-merit h4{font-size:16px;font-weight:700;margin-bottom:10px;}
.perf-merit p{font-size:13px;color:rgba(255,255,255,.45);line-height:1.85;}
.perf-cta{margin-top:clamp(40px,5vw,60px);}

/* ===================================================================
   COMPARE
   =================================================================== */
#compare{background:var(--paper-2);}
.compare-head{text-align:center;max-width:620px;margin:0 auto clamp(40px,5vw,64px);}
.comp{width:100%;border-collapse:collapse;background:var(--surface);
  border:1px solid var(--line);border-radius:16px;overflow:hidden;}
.comp th,.comp td{padding:18px 22px;text-align:center;font-size:14px;border-bottom:1px solid var(--line-soft);}
.comp thead th{font-family:var(--ff-disp);font-size:13px;font-weight:700;letter-spacing:.04em;padding:20px 22px;}
.comp thead th:first-child{text-align:left;width:34%;color:var(--sub);background:var(--paper);}
.comp thead .col-ad{background:var(--ink);color:var(--paper);font-size:18px;letter-spacing:-.01em;}
.comp thead .col-other{color:var(--sub);background:var(--paper);}
.comp td:first-child{text-align:left;font-weight:500;color:var(--ink);}
.comp tbody td.ad{background:rgba(30,34,220,.04);font-weight:500;}
.comp tr:last-child td{border-bottom:none;}
.comp .yes{color:var(--blue);font-weight:700;}
.comp .no{color:#b4b1a6;}
.comp .mark{display:inline-block;width:18px;font-family:var(--ff-disp);font-weight:800;margin-right:6px;}

/* ===================================================================
   WHY
   =================================================================== */
#why{background:var(--paper);}
.why-head{text-align:center;max-width:620px;margin:0 auto clamp(48px,6vw,80px);}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--line);}
.why-card{padding:clamp(30px,3vw,44px) clamp(20px,2vw,32px) 36px;border-bottom:1px solid var(--line);
  border-right:1px solid var(--line);transition:background .3s;}
.why-card:nth-child(4n){border-right:none;}
.why-card:hover{background:var(--surface);}
.why-n{font-family:var(--ff-disp);font-weight:800;font-size:clamp(40px,4vw,60px);
  letter-spacing:-.03em;color:var(--ink);line-height:1;margin-bottom:24px;
  -webkit-text-stroke:1px var(--ink);color:transparent;}
.why-card:hover .why-n{color:var(--blue);-webkit-text-stroke-color:var(--blue);}
.why-card h3{font-size:18px;font-weight:700;line-height:1.4;margin-bottom:12px;}
.why-card p{font-size:13px;line-height:1.95;color:var(--sub);}

/* ===================================================================
   SERVICES
   =================================================================== */
#services{background:var(--ink);color:var(--paper);}
#services .eyebrow{color:#9b9af0;}
#services .eyebrow::before{background:#9b9af0;}
#services .sec-head .s-title{color:var(--paper);}
#services .s-lead{color:rgba(255,255,255,.5);}
.svc-list{border-top:1px solid var(--ink-line);}
.svc-row{display:grid;grid-template-columns:80px 1fr 1.4fr;gap:40px;align-items:start;
  padding:clamp(28px,3.2vw,44px) 0;border-bottom:1px solid var(--ink-line);transition:padding-left .35s;}
.svc-row:hover{padding-left:20px;}
.svc-row .num{font-family:var(--ff-disp);font-weight:800;font-size:18px;color:#9b9af0;letter-spacing:.04em;}
.svc-row h3{font-size:clamp(20px,2.1vw,28px);font-weight:700;line-height:1.3;}
.svc-row p{font-size:14px;line-height:2;color:rgba(255,255,255,.5);max-width:52ch;}

/* ===================================================================
   U-POWERS
   =================================================================== */
#upowers{background:var(--paper);}
.up-wrap{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);align-items:center;}
.up-title{font-family:var(--ff-jp);font-weight:700;font-size:clamp(30px,4vw,52px);line-height:1.12;
  letter-spacing:-.01em;margin-top:20px;}
.up-title b{font-family:var(--ff-disp);font-weight:800;color:var(--blue);display:block;letter-spacing:-.02em;}
.up-desc{font-size:14.5px;line-height:2.05;color:var(--ink-2);margin-top:24px;}
.up-desc b{color:var(--ink);font-weight:700;}
.up-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:26px;}
.up-tag{font-size:12px;font-weight:500;line-height:1.5;padding:7px 15px;border-radius:100px;border:1px solid var(--line);color:var(--ink-2);}
.up-tag.hi{background:var(--ink);color:var(--paper);border-color:var(--ink);}
.up-stats{display:flex;gap:clamp(20px,3vw,44px);margin:32px 0;}
.up-stat .n{font-family:var(--ff-disp);font-weight:800;font-size:clamp(28px,3vw,42px);letter-spacing:-.02em;line-height:1;}
.up-stat .l{font-size:11px;color:var(--sub);margin-top:9px;}
.up-panel{background:var(--ink);color:var(--paper);border-radius:22px;padding:clamp(28px,3vw,44px);}
.up-card{padding:22px 0;border-bottom:1px solid var(--ink-line);}
.up-card:first-child{padding-top:0;}
.up-card:last-of-type{border-bottom:none;}
.up-card h4{font-size:15px;font-weight:700;margin-bottom:9px;display:flex;align-items:baseline;gap:12px;}
.up-card h4 span{font-family:var(--ff-disp);font-size:12px;font-weight:800;color:#9b9af0;}
.up-card p{font-size:13px;line-height:1.85;color:rgba(255,255,255,.45);}
.up-plat{margin-top:24px;padding-top:22px;border-top:1px solid var(--ink-line);}
.up-plat .lab{font-family:var(--ff-disp);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:12px;}
.up-plat .row{display:flex;flex-wrap:wrap;gap:8px;}
.up-plat .row span{font-size:12px;color:rgba(255,255,255,.6);border:1px solid var(--ink-line);padding:6px 13px;border-radius:100px;}

/* ===================================================================
   FLOW
   =================================================================== */
#flow{background:var(--paper-2);}
.flow-head{text-align:center;max-width:620px;margin:0 auto clamp(44px,5vw,72px);}
.flow-steps{display:grid;grid-template-columns:repeat(5,1fr);gap:0;border-top:1px solid var(--line);}
.flow-step{padding:30px clamp(14px,1.6vw,24px) 34px;border-right:1px solid var(--line);position:relative;}
.flow-step:last-child{border-right:none;}
.flow-num{font-family:var(--ff-disp);font-weight:800;font-size:clamp(34px,3.2vw,48px);
  letter-spacing:-.03em;line-height:1;color:var(--ink);}
.flow-tag{font-family:var(--ff-disp);font-size:10px;font-weight:600;letter-spacing:.1em;
  text-transform:uppercase;color:var(--hot);margin:18px 0 10px;display:block;}
.flow-step h3{font-size:17px;font-weight:700;margin-bottom:9px;}
.flow-step p{font-size:12.5px;line-height:1.85;color:var(--sub);}
.flow-bottom{margin-top:clamp(36px,4vw,56px);background:var(--ink);color:var(--paper);
  border-radius:20px;padding:clamp(28px,3.4vw,44px) clamp(28px,4vw,56px);
  display:flex;align-items:center;justify-content:space-between;gap:28px;flex-wrap:wrap;}
.flow-bottom h4{font-size:clamp(19px,2vw,26px);font-weight:700;margin-bottom:8px;}
.flow-bottom p{font-size:13.5px;color:rgba(255,255,255,.5);line-height:1.8;}
.flow-bottom .btn-fill{background:var(--paper);color:var(--ink);}
.flow-bottom .btn-fill:hover{background:var(--blue);color:#fff;}

/* ===================================================================
   RESULTS
   =================================================================== */
#results{background:var(--paper);}
.res-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;
  margin-bottom:clamp(40px,5vw,64px);flex-wrap:wrap;}
.res-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,28px);}
.res-card{background:var(--surface);border:1px solid var(--line);border-radius:16px;overflow:hidden;
  transition:.3s;display:flex;flex-direction:column;}
.res-card:hover{transform:translateY(-5px);box-shadow:0 20px 50px -28px rgba(22,21,15,.35);}
.res-thumb{aspect-ratio:4/3;position:relative;border-bottom:1px solid var(--line);}
.res-body{padding:24px 24px 26px;display:flex;flex-direction:column;flex:1;}
.res-tag{font-family:var(--ff-disp);font-size:10px;font-weight:600;letter-spacing:.12em;
  text-transform:uppercase;color:var(--blue);margin-bottom:14px;}
.res-card h3{font-size:18px;font-weight:700;line-height:1.45;margin-bottom:10px;}
.res-card p{font-size:13px;line-height:1.9;color:var(--sub);flex:1;}
.res-stats{display:flex;gap:26px;margin-top:22px;padding-top:20px;border-top:1px solid var(--line);}
.res-stats .n{font-family:var(--ff-disp);font-weight:800;font-size:26px;letter-spacing:-.02em;line-height:1;color:var(--ink);}
.res-stats .l{font-size:10px;color:var(--sub);margin-top:7px;}

/* placeholder image */
.ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:var(--paper-2);
  background-image:repeating-linear-gradient(135deg,rgba(22,21,15,.05) 0 1px,transparent 1px 11px);}
.ph span{font-family:var(--ff-disp);font-size:10px;font-weight:600;letter-spacing:.18em;
  text-transform:uppercase;color:var(--sub);background:var(--surface);padding:6px 12px;border-radius:100px;
  border:1px solid var(--line);}

/* ===================================================================
   BLOG
   =================================================================== */
#blog{background:var(--paper);border-top:1px solid var(--line);}
.blog-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;
  margin-bottom:clamp(40px,5vw,60px);flex-wrap:wrap;}
.blog-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:clamp(20px,3vw,44px);}
.blog-main{cursor:pointer;}
.blog-main .thumb{aspect-ratio:16/10;position:relative;border-radius:16px;overflow:hidden;border:1px solid var(--line);margin-bottom:22px;}
.blog-main .meta{font-family:var(--ff-disp);font-size:11px;font-weight:600;letter-spacing:.08em;
  color:var(--blue);margin-bottom:12px;display:flex;gap:12px;align-items:center;}
.blog-main h3{font-size:clamp(20px,2.2vw,28px);font-weight:700;line-height:1.4;margin-bottom:12px;max-width:24ch;}
.blog-main p{font-size:13.5px;line-height:1.9;color:var(--sub);max-width:46ch;}
.blog-main .blog-body{display:flex;flex-wrap:wrap;align-items:flex-start;
  column-gap:clamp(28px,3vw,52px);row-gap:14px;}
.blog-main .blog-body h3{margin-bottom:0;flex:1 1 300px;}
.blog-main .blog-body p{flex:1 1 240px;margin-top:7px;}
.blog-sub{display:flex;flex-direction:column;}
.bsmall{display:flex;gap:18px;padding:22px 0;border-bottom:1px solid var(--line);cursor:pointer;transition:.25s;}
.blog-sub .bsmall:first-child{padding-top:0;}
.bsmall:hover{padding-left:10px;}
.bsmall .idx{font-family:var(--ff-disp);font-weight:800;font-size:13px;color:var(--blue);flex-shrink:0;width:24px;}
.bsmall .meta{font-family:var(--ff-disp);font-size:11px;font-weight:600;letter-spacing:.06em;color:var(--sub);margin-bottom:7px;}
.bsmall h4{font-size:14.5px;font-weight:700;line-height:1.55;}

/* ===================================================================
   CONTACT
   =================================================================== */
#contact{background:var(--ink);color:var(--paper);}
.con-wrap{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(40px,6vw,88px);align-items:start;}
#contact .eyebrow{color:#9b9af0;}
#contact .eyebrow::before{background:#9b9af0;}
.con-title{font-family:var(--ff-jp);font-weight:700;font-size:clamp(30px,4.4vw,60px);line-height:1.12;
  letter-spacing:-.01em;margin-top:20px;}
.con-title em{font-family:var(--ff-mincho);font-style:normal;font-weight:700;letter-spacing:.03em;background:linear-gradient(100deg,#8aa0ff,#ff6db5);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;}
.con-desc{font-size:14.5px;line-height:2.05;color:rgba(255,255,255,.55);margin-top:24px;max-width:42ch;}
.con-info{margin-top:36px;border-top:1px solid var(--ink-line);}
.cii{display:flex;justify-content:space-between;gap:16px;padding:16px 0;border-bottom:1px solid var(--ink-line);}
.cii .k{font-family:var(--ff-disp);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.4);}
.cii .v{font-size:14px;font-weight:500;text-align:right;}
.cii .v a{color:#9b9af0;}

.cform{background:rgba(255,255,255,.03);border:1px solid var(--ink-line);border-radius:22px;padding:clamp(26px,3vw,40px);}
.fg{display:flex;flex-direction:column;gap:8px;margin-bottom:16px;}
.fg label{font-family:var(--ff-disp);font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.55);}
.fg input,.fg select,.fg textarea{
  background:rgba(255,255,255,.04);border:1px solid var(--ink-line);border-radius:10px;
  color:#fff;padding:13px 15px;font-size:14px;font-family:var(--ff-jp);outline:none;transition:.2s;width:100%;
}
.fg input::placeholder,.fg textarea::placeholder{color:rgba(255,255,255,.3);}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:#9b9af0;background:rgba(255,255,255,.06);}
.fg select option{background:#16150F;}
.fg textarea{resize:vertical;min-height:112px;}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.fsub{width:100%;background:var(--grad);color:#fff;border:none;border-radius:100px;
  font-family:var(--ff-disp);font-size:14px;font-weight:700;letter-spacing:.02em;padding:16px;cursor:pointer;
  transition:.25s;margin-top:8px;display:flex;align-items:center;justify-content:center;gap:9px;
  box-shadow:0 12px 30px -14px rgba(236,26,123,.6);}
.fsub:hover{filter:brightness(1.07);}
.fnote{font-size:11px;color:rgba(255,255,255,.35);text-align:center;margin-top:14px;}

/* ===================================================================
   FOOTER
   =================================================================== */
footer{background:var(--ink);color:var(--paper);padding:clamp(56px,7vw,90px) var(--gutter) 36px;border-top:1px solid var(--ink-line);}
.ft-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:clamp(40px,5vw,64px);border-bottom:1px solid var(--ink-line);}
.ft-brand{margin-bottom:18px;}
.ft-brand img{height:30px;width:auto;display:block;}
.ft-brand + p{font-size:13px;line-height:1.95;color:rgba(255,255,255,.4);max-width:38ch;}
.ft-brand + p a{color:#9b9af0;}
.ft-col h5{font-family:var(--ff-disp);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:18px;}
.ft-col ul{list-style:none;display:flex;flex-direction:column;gap:12px;}
.ft-col a{font-size:13.5px;color:rgba(255,255,255,.6);transition:.2s;}
.ft-col a:hover{color:#fff;}
.ft-bot{display:flex;justify-content:space-between;gap:16px;padding-top:26px;flex-wrap:wrap;}
.ft-bot p{font-family:var(--ff-disp);font-size:11px;letter-spacing:.06em;color:rgba(255,255,255,.32);}

/* ===================================================================
   FADE-IN
   =================================================================== */
@media (prefers-reduced-motion:no-preference){
  .fi{opacity:0;transform:translateY(22px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1);}
  .fi.v{opacity:1;transform:none;}
}

/* toast */
.toast{position:fixed;bottom:28px;left:50%;
  background:var(--ink);color:var(--paper);border:1px solid var(--ink-line);
  padding:14px 26px;border-radius:100px;font-size:13px;font-weight:500;z-index:999;
  transform:translate(-50%,90px);opacity:0;transition:.4s cubic-bezier(.16,1,.3,1);}
.toast.show{transform:translate(-50%,0);opacity:1;}

/* ===================================================================
   BRIGHT THEME OVERRIDES  (lighten dark sections, add imagery)
   =================================================================== */
:root{--tint:#ECEEFE;--tint2:#F6EDFB;}

.imgslot{display:block;width:100%;height:auto;background:linear-gradient(135deg,#E7EBFF,#FCE7F1);
  border-radius:18px;overflow:hidden;box-shadow:0 26px 64px -42px rgba(42,69,230,.5);}

/* MARQUEE -> bright gradient bar */
.marquee{border-top:0;border-bottom:0;background:var(--grad);color:#fff;}
.marquee .star{color:#fff;opacity:.6;}

/* PERFORMANCE -> light */
#performance{background:var(--tint);color:var(--ink);}
#performance .eyebrow{color:var(--blue);}
#performance .eyebrow::before{background:var(--blue);}
.perf-h{color:var(--ink);}
.perf-h em{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;}
.perf-sub{color:var(--sub);}
.perf-card{background:#fff;border:1px solid var(--line);}
.perf-card.yes{background:var(--grad);border:0;color:#fff;box-shadow:0 30px 60px -34px rgba(122,54,198,.6);}
.perf-card.yes .perf-pct{color:#fff;}
.perf-card.yes .perf-pct .u{color:rgba(255,255,255,.85);}
.perf-card.yes .perf-eg{color:rgba(255,255,255,.92);}
.perf-card.yes .perf-eg b{color:#fff;}
.perf-card.no{color:var(--ink);}
.perf-card.no .perf-pct{color:var(--blue);}
.perf-card.no .perf-pct .u{color:var(--sub);}
.perf-card.no .perf-eg{color:var(--sub);}
.perf-card.no .perf-eg b{color:var(--ink);}
.perf-card.yes .perf-flag{background:#fff;color:var(--blue);}
.perf-card.no .perf-flag{border:1px solid var(--line);color:var(--sub);}
.perf-vs{color:var(--sub);}
.perf-merits{background:var(--line);border:1px solid var(--line);}
.perf-merit{background:#fff;}
.perf-merit .mi{color:var(--blue);}
.perf-merit h4{color:var(--ink);}
.perf-merit p{color:var(--sub);}
/* highlight the 3rd merit a touch */
.perf-merit:nth-child(3){position:relative;
  background:
    radial-gradient(130% 90% at 50% -10%,rgba(255,255,255,.95),rgba(255,255,255,0) 58%),
    linear-gradient(155deg,#EDE2FF 0%,#FFE6F2 52%,#FFF1E6 100%);
  box-shadow:inset 0 0 0 1px rgba(122,54,198,.22),0 1px 0 rgba(255,255,255,.9) inset;}
.perf-merit:nth-child(3)::before{content:'';position:absolute;left:0;right:0;top:0;height:4px;background:var(--grad);}
.perf-merit:nth-child(3) .mi{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;}
.perf-merit:nth-child(3) h4{color:var(--ink);}

/* SERVICES -> light + image split */
#services{background:var(--paper);color:var(--ink);}
#services .eyebrow{color:var(--blue);}
#services .eyebrow::before{background:var(--blue);}
#services .sec-head .s-title{color:var(--ink);}
#services .s-lead{color:var(--sub);}
.svc-split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(34px,4.5vw,72px);align-items:center;}
@media(min-width:769px){
  #services .sec-head .svc-lead{max-width:none;white-space:nowrap;}
}
.svc-list{border-top:1px solid var(--line);}
.svc-row{border-bottom:1px solid var(--ink-line);border-bottom:1px solid var(--line);grid-template-columns:64px 1fr;}
.svc-row .num{color:var(--blue);}
.svc-row h3{color:var(--ink);}
.svc-row p{color:var(--sub);}
.svc-row .svc-desc{grid-column:1/-1;padding-left:64px;margin-top:4px;}
.svc-visual{min-height:clamp(360px,42vw,520px);align-self:stretch;}

/* U-POWERS -> light + image */
.up-title{color:var(--ink);}
.up-desc{color:var(--ink-2);}
.up-desc b{color:var(--ink);}
.up-tag{border-color:var(--line);color:var(--ink-2);white-space:nowrap;flex:0 0 auto;}
.up-tag.hi{background:var(--grad);border-color:transparent;color:#fff;}
.up-stat .n{color:var(--ink);white-space:nowrap;}
.up-stat .l{color:var(--sub);}
.up-img{min-height:clamp(340px,40vw,500px);}
.up-features{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:clamp(34px,4vw,56px);}
.up-feature{background:#fff;border:1px solid var(--line);border-radius:18px;padding:28px 26px;transition:.25s;}
.up-feature:hover{box-shadow:0 18px 44px -30px rgba(42,69,230,.4);transform:translateY(-3px);}
.up-feature h4{font-size:15px;font-weight:700;color:var(--ink);margin-bottom:10px;display:flex;gap:11px;align-items:baseline;}
.up-feature h4 span{font-family:var(--ff-disp);font-size:12px;font-weight:800;color:var(--blue);}
.up-feature p{font-size:13px;line-height:1.85;color:var(--sub);}

/* CONTACT -> light */
#contact{background:var(--tint2);color:var(--ink);}
#contact .eyebrow{color:var(--blue);}
#contact .eyebrow::before{background:var(--blue);}
.con-title{color:var(--ink);}
.con-title em{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;}
.con-desc{color:var(--sub);}
.con-info{border-top:1px solid var(--line);}
.cii{border-bottom:1px solid var(--line);}
.cii .k{color:var(--sub);}
.cii .v{color:var(--ink);}
.cii .v a{color:var(--blue);}
.cform{background:#fff;border:1px solid var(--line);box-shadow:0 30px 70px -50px rgba(42,69,230,.5);}
.fg label{color:var(--sub);}
.fg input,.fg select,.fg textarea{background:var(--paper);border:1px solid var(--line);color:var(--ink);}
.fg input::placeholder,.fg textarea::placeholder{color:#9aa0b4;}
.fg select option{background:#fff;color:var(--ink);}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px rgba(42,69,230,.1);}

/* GALLERY (SNS posts) */
#gallery{background:var(--paper);border-top:1px solid var(--line);}
.gal-head{text-align:center;max-width:600px;margin:0 auto clamp(36px,5vw,56px);}
.gal-head p{font-size:14px;color:var(--sub);line-height:1.9;margin-top:12px;max-width:none;}
.gal-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:clamp(10px,1.2vw,16px);}
.gal-grid .imgslot{aspect-ratio:1;min-height:0;border-radius:16px;}

/* image slots that fill a wrapper */
.res-thumb image-slot,.blog-main .thumb image-slot{display:block;width:100%;height:100%;}


@media(max-width:1024px){
  #hero{min-height:auto;}
  .hero-inner{grid-template-columns:1fr;gap:clamp(28px,5vw,40px);}
  .hero-left{order:1;}
  .hero-right{display:none;}
  .hero-proof{justify-content:flex-start;}
  .sec-head{grid-template-columns:1fr;gap:18px;}
  .sec-head .s-lead{justify-self:start;}
  .str-row{display:block;}
  .str-idx{display:flex;align-items:baseline;gap:10px;}
  .str-idx .b{margin-top:0;}
  .str-ico{display:block;width:36px;height:36px;margin-top:0;margin-left:auto;align-self:center;}
  .str-row h3{margin-top:16px;}
  .str-row .str-body-2{grid-column:1/-1;padding-left:0;margin-top:16px;}
  .why-grid{grid-template-columns:1fr 1fr;}
  .why-card:nth-child(4n){border-right:1px solid var(--line);}
  .why-card:nth-child(2n){border-right:none;}
  .svc-row{grid-template-columns:60px 1fr;}
  .svc-row .svc-desc{grid-column:1/-1;padding-left:100px;}
  .up-wrap{grid-template-columns:1fr;}
  .flow-steps{grid-template-columns:repeat(2,1fr);}
  .flow-step{border-bottom:1px solid var(--line);}
  .res-grid{grid-template-columns:1fr 1fr;}
  .blog-grid{grid-template-columns:1fr;}
  .con-wrap{grid-template-columns:1fr;}
}
@media(max-width:680px){
  .nav-links{display:none;}
  .nav-cta{display:none;}
  .hamburger{display:flex;flex-direction:column;gap:5px;cursor:pointer;padding:6px;}
  .hamburger span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.3s;}
  .hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
  .hamburger.open span:nth-child(2){opacity:0;}
  .hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
  .mobile-menu{position:fixed;inset:0;background:var(--paper);z-index:300;display:flex;
    flex-direction:column;align-items:center;justify-content:center;gap:6px;opacity:0;pointer-events:none;transition:.3s;}
  .mobile-menu.open{opacity:1;pointer-events:all;}
  .mobile-close{position:absolute;top:18px;right:18px;width:44px;height:44px;border:0;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;}
  .mobile-close span{position:absolute;width:24px;height:2px;background:var(--ink);border-radius:2px;}
  .mobile-close span:nth-child(1){transform:rotate(45deg);}
  .mobile-close span:nth-child(2){transform:rotate(-45deg);}
  .mobile-menu a{font-size:20px;font-weight:700;padding:12px;}
  body.menu-open{overflow:hidden;}
  .mobile-menu .mob-cta{background:var(--ink);color:var(--paper);padding:13px 32px;border-radius:100px;margin-top:14px;font-family:var(--ff-disp);}
  .perf-grid{grid-template-columns:1fr;}
  .perf-vs{padding:6px 0;}
  .perf-merits{grid-template-columns:1fr;}
  .why-grid{grid-template-columns:1fr;}
  .why-card{border-right:none !important;}
  .flow-steps{grid-template-columns:1fr;}
  .flow-step{border-right:none;}
  .res-grid{grid-template-columns:1fr;}
  .str-row .str-body-2{padding-left:0;}
  .svc-row{grid-template-columns:1fr;gap:14px;}
  .svc-row .svc-desc{padding-left:0;}
  .frow{grid-template-columns:1fr;}
  .ft-top{grid-template-columns:1fr;gap:32px;}
  .comp{font-size:12px;}
  .comp th,.comp td{padding:13px 12px;}
  .svc-row{grid-template-columns:48px 1fr;}
  .svc-row .svc-desc{padding-left:48px;}
}

/* new bright sections — responsive */
@media(max-width:1024px){
  .svc-split{grid-template-columns:1fr;gap:32px;}
  .svc-visual{order:-1;min-height:300px;}
  .up-features{grid-template-columns:1fr;}
  .gal-grid{grid-template-columns:repeat(3,1fr);}
}
@media(max-width:680px){
  .gal-grid{grid-template-columns:repeat(2,1fr);}
}

/* ===================================================================
   SUBPAGES (Company / Legal)
   =================================================================== */
.subpage{max-width:1000px;margin:0 auto;padding:clamp(120px,16vh,176px) var(--pad) clamp(72px,10vw,120px);}
.sub-hero{margin-bottom:clamp(40px,6vw,68px);}
.sub-hero .s-title{margin-top:18px;}
.sub-tagline{font-size:clamp(17px,1.8vw,21px);font-weight:700;color:var(--ink);margin-top:22px;}
.sub-sub{font-size:14px;color:var(--sub);margin-top:7px;}
.sub-intro{font-size:15px;line-height:2.05;color:var(--sub);margin-top:18px;max-width:min(820px,100%);text-wrap:pretty;}

.info-table{width:100%;border-collapse:collapse;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--surface);}
.info-table th,.info-table td{padding:17px 24px;text-align:left;vertical-align:top;font-size:14.5px;line-height:1.95;border-bottom:1px solid var(--line);}
.info-table th{width:210px;font-weight:700;color:var(--ink);background:var(--paper);white-space:nowrap;}
.info-table td{color:var(--ink-2);}
.info-table td .note{display:block;font-size:12px;color:var(--sub);margin-top:4px;}
.info-table tr:last-child th,.info-table tr:last-child td{border-bottom:none;}

.vmv-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:clamp(40px,5vw,64px);}
.vmv-card{background:var(--surface);border:1px solid var(--line);border-radius:20px;padding:clamp(28px,3vw,40px);}
.vmv-label{display:inline-block;font-family:var(--ff-disp);font-size:11px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--blue);margin-bottom:16px;}
.vmv-title{font-size:clamp(18px,1.8vw,23px);font-weight:700;line-height:1.45;margin-bottom:14px;color:var(--ink);}
.vmv-card p{font-size:13.5px;line-height:1.95;color:var(--sub);}

.value-wrap{margin-top:clamp(48px,6vw,80px);}
.value-head{text-align:center;margin-bottom:clamp(32px,4vw,44px);}
.value-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;}
.value-card{background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:28px 22px;transition:.25s;}
.value-card:hover{box-shadow:0 18px 44px -28px rgba(42,69,230,.35);transform:translateY(-3px);}
.value-num{font-family:var(--ff-disp);font-weight:800;font-size:36px;color:transparent;-webkit-text-stroke:1px var(--blue);line-height:1;margin-bottom:18px;}
.value-card h3{font-size:14px;font-weight:700;margin-bottom:9px;color:var(--ink);}
.value-card p{font-size:12px;line-height:1.85;color:var(--sub);}

.greeting{background:linear-gradient(135deg,var(--tint),var(--tint2));border:1px solid var(--line);border-radius:24px;padding:clamp(32px,4vw,56px);margin-top:clamp(48px,6vw,80px);}
.greeting .vmv-label{margin-bottom:20px;}
.greeting p{font-size:14.5px;line-height:2.05;color:var(--ink-2);margin-bottom:16px;}
.greeting .sig{margin-top:28px;padding-top:22px;border-top:1px solid var(--line);font-size:14px;line-height:1.9;color:var(--ink);}

.legal-section{padding:clamp(26px,3vw,38px) 0;border-bottom:1px solid var(--line);}
.legal-section:first-of-type{padding-top:0;}
.legal-section:last-of-type{border-bottom:none;}
.legal-section h2{font-size:17px;font-weight:700;color:var(--ink);margin-bottom:14px;display:flex;gap:13px;align-items:baseline;}
.legal-section h2 .ln{font-family:var(--ff-disp);font-size:13px;font-weight:800;color:var(--blue);}
.legal-section p{font-size:14px;line-height:1.95;color:var(--sub);margin-bottom:10px;}
.legal-section ul{margin:14px 0 0;padding:0;list-style:none;display:flex;flex-direction:column;gap:8px;}
.legal-section ul li{font-size:14px;line-height:1.8;color:var(--ink-2);position:relative;padding-left:18px;}
.legal-section ul li::before{content:'';position:absolute;left:2px;top:.72em;width:5px;height:5px;border-radius:50%;background:var(--blue);}
.legal-date{font-size:13px;color:var(--sub);margin-top:32px;}

.sub-back{margin-top:clamp(48px,6vw,72px);}

@media(max-width:768px){
  .vmv-grid{grid-template-columns:1fr;}
  .value-grid{grid-template-columns:repeat(2,1fr);}
  .info-table th{width:120px;font-size:13px;}
  .info-table th,.info-table td{padding:14px 16px;font-size:13.5px;}
}
@media(max-width:480px){
  .value-grid{grid-template-columns:1fr;}
}


/* =====================================================================
   WORDPRESS THEME — image handling (replaces <image-slot>)
   ===================================================================== */
.res-thumb img,.blog-main .thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;}
.res-thumb,.blog-main .thumb{background:var(--paper-2);}
.svc-visual,.up-img{position:relative;overflow:hidden;border-radius:20px;background:var(--paper-2);}
.svc-visual img,.up-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;}
.res-thumb a{display:block;position:absolute;inset:0;}
.blog-main .thumb a{display:block;position:absolute;inset:0;}
.res-card a.res-link{color:inherit;text-decoration:none;display:flex;flex-direction:column;height:100%;}
.bsmall a{color:inherit;text-decoration:none;display:flex;gap:18px;flex:1;}
.blog-main h3 a,.res-card h3 a{color:inherit;text-decoration:none;}
/* single article / archive */
.article-wrap{max-width:760px;margin:0 auto;}
.article-wrap .post-content{font-size:15px;line-height:2;color:var(--ink-2);}
.article-wrap .post-content h2{font-size:24px;font-weight:700;margin:36px 0 14px;color:var(--ink);}
.article-wrap .post-content h3{font-size:19px;font-weight:700;margin:28px 0 12px;color:var(--ink);}
.article-wrap .post-content p{margin-bottom:18px;}
.article-wrap .post-content img{border-radius:14px;margin:20px 0;}
.article-wrap .post-content ul,.article-wrap .post-content ol{margin:0 0 18px 1.4em;}
.article-wrap .post-content li{margin-bottom:8px;line-height:1.9;}
.article-wrap .post-content a{color:var(--blue);text-decoration:underline;text-underline-offset:2px;}
.article-hero{aspect-ratio:16/9;border-radius:18px;overflow:hidden;margin:26px 0 0;position:relative;background:var(--paper-2);}
.article-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.archive-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,28px);}
@media(max-width:880px){.archive-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){.archive-grid{grid-template-columns:1fr;}}
.pager{display:flex;gap:10px;justify-content:center;margin-top:48px;flex-wrap:wrap;}
.pager a,.pager span{padding:9px 16px;border:1px solid var(--line);border-radius:10px;font-size:13px;color:var(--ink-2);}
.pager .current{background:var(--ink);color:#fff;border-color:var(--ink);}
.empty-note{font-size:13px;color:var(--sub);padding:22px;border:1px dashed var(--line);border-radius:14px;text-align:center;}

/* contact form — flash message + honeypot */
.adk-hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden;}
.form-flash{font-size:13.5px;line-height:1.7;padding:14px 16px;border-radius:12px;margin-bottom:20px;border:1px solid var(--line);}
.form-flash.ok{background:rgba(31,138,91,.10);border-color:rgba(31,138,91,.35);color:#15623f;}
.form-flash.err{background:rgba(236,26,123,.08);border-color:rgba(236,26,123,.32);color:#a01259;}
