/*
Theme Name: GREEK Modern
Theme URI: https://www.greek.co.jp/
Author: GREEK Inc.
Description: 株式会社グリーク コーポレートサイト リニューアル。買取事業を前面に出した編集的デザイン。元デザインへ戻すには管理画面「外観 > テーマ」で「Snow Monkey Child」を有効化（または wp theme activate snow-monkey-child-master）。
Version: 1.0.4
License: GNU General Public License v2 or later
Text Domain: greek-modern
*/

/* ========================================================================
   GREEK Inc. — editorial / buying-first corporate theme
   ===================================================================== */
:root{
  --ink:#14181d; --ink-soft:#4a525c; --line:#e4e7ec; --paper:#ffffff; --tint:#f5f7fa;
  --navy:#0a3a78; --blue:#1f7fd0; --cyan:#36c5e0; --accent:#e7b53c;
  --maxw:1180px;
  --ff-serif:"Shippori Mincho B1","Hiragino Mincho ProN",serif;
  --ff-sans:"Zen Kaku Gothic New","Hiragino Kaku Gothic ProN","Noto Sans JP",sans-serif;
  --ff-en:"Jost",sans-serif;
}
*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family:var(--ff-sans); color:var(--ink); background:var(--paper);
  line-height:1.85; font-size:16px; -webkit-font-smoothing:antialiased;
  font-feature-settings:"palt"; overflow-x:hidden;
}
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; height:auto; display:block; }
em{ font-style:normal; }
.container{ width:90%; max-width:var(--maxw); margin-inline:auto; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5em;
  font-family:var(--ff-sans); font-weight:700; font-size:.95rem;
  padding:.95em 1.8em; border-radius:2px; line-height:1.2;
  transition:transform .25s ease, background .25s ease, color .25s ease, box-shadow .25s ease;
  white-space:nowrap; cursor:pointer; border:none;
}
.btn--primary{ background:var(--navy); color:#fff; }
.btn--primary:hover{ background:var(--blue); transform:translateY(-2px); box-shadow:0 10px 24px -12px rgba(10,58,120,.7); }
.btn--ghost{ background:transparent; color:var(--navy); border:1px solid var(--navy); }
.btn--ghost:hover{ background:var(--navy); color:#fff; }
.btn--ghost-light{ color:#fff; border-color:rgba(255,255,255,.55); }
.btn--ghost-light:hover{ background:#fff; color:var(--navy); }
.btn--cta{ background:var(--accent); color:var(--ink); padding:.7em 1.4em; }
.btn--cta:hover{ filter:brightness(1.05); transform:translateY(-2px); }
.btn--lg{ padding:1.1em 2.4em; font-size:1.05rem; }

/* ---------- Header ---------- */
.site-header{
  position:sticky; top:0; z-index:50; background:#fff;
  border-bottom:1px solid var(--line); box-shadow:0 1px 12px -8px rgba(20,24,29,.35);
}
.header-inner{ width:90%; max-width:var(--maxw); margin-inline:auto; display:flex; align-items:center; gap:1.6rem; height:74px; }
.brand-logo{ height:36px; width:auto; }
.nav{ display:flex; gap:1.5rem; margin-left:auto; white-space:nowrap; }
.nav a{ font-size:.9rem; font-weight:500; color:var(--ink-soft); position:relative; padding:.2em 0; }
.nav a::after{ content:""; position:absolute; left:0; bottom:-2px; width:0; height:2px; background:var(--blue); transition:width .25s ease; }
.nav a:hover{ color:var(--ink); } .nav a:hover::after{ width:100%; }
.btn--cta{ flex:none; }
.nav-toggle{ display:none; }

/* ---------- Hero ---------- */
.hero{ position:relative; padding:5.5rem 0 0; background:var(--paper); }
.hero-grid{ width:90%; max-width:var(--maxw); margin-inline:auto; display:grid; grid-template-columns:1.15fr .85fr; gap:3.5rem; align-items:center; }
.hero-eyebrow{ font-family:var(--ff-en); letter-spacing:.28em; font-size:.8rem; font-weight:600; color:var(--blue); margin-bottom:1.6rem; }
.hero-title{ font-family:var(--ff-serif); font-weight:700; font-size:clamp(2.4rem,5vw,4rem); line-height:1.28; letter-spacing:.01em; margin-bottom:1.8rem; }
.hero-title em{ color:var(--navy); position:relative; }
.hero-title em::after{ content:""; position:absolute; left:-2px; right:-2px; bottom:.08em; height:.18em; background:var(--accent); opacity:.55; z-index:-1; }
.hero-lead{ color:var(--ink-soft); font-size:1.02rem; max-width:34em; margin-bottom:2.2rem; }
.hero-lead strong{ color:var(--ink); font-weight:700; }
.hero-actions{ display:flex; gap:1rem; flex-wrap:wrap; margin-bottom:3rem; }
.hero-stats{ list-style:none; display:flex; gap:2.6rem; flex-wrap:wrap; border-top:1px solid var(--line); padding-top:1.8rem; }
.hero-stats li{ display:flex; flex-direction:column; }
.stat-num{ font-family:var(--ff-en); font-weight:600; font-size:2rem; color:var(--navy); line-height:1.1; }
.stat-num small{ font-size:.9rem; font-weight:500; margin-left:.15em; }
.stat-label{ font-size:.8rem; color:var(--ink-soft); margin-top:.3rem; }
.hero-visual{ position:relative; aspect-ratio:4/5; }
.hero-mark{ position:absolute; inset:0; background:radial-gradient(120% 120% at 80% 10%, #2a9fd4 0%, var(--navy) 70%); border-radius:4px; overflow:hidden; display:flex; align-items:center; justify-content:center; }
.hero-mark::before{ content:""; position:absolute; inset:0; background-image:linear-gradient(rgba(255,255,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.06) 1px,transparent 1px); background-size:42px 42px; }
.hero-mark-g{ font-family:var(--ff-en); font-weight:600; color:#fff; font-size:clamp(10rem,22vw,18rem); line-height:1; opacity:.96; text-shadow:0 8px 40px rgba(0,0,0,.25); }
.hero-tags{ position:absolute; left:-18px; bottom:24px; display:flex; flex-direction:column; gap:.5rem; align-items:flex-start; }
.hero-tags span{ background:#fff; color:var(--navy); font-weight:700; font-size:.82rem; padding:.45em 1em; border-radius:2px; box-shadow:0 8px 22px -14px rgba(0,0,0,.5); }
.hero-marquee{ margin-top:4.5rem; border-block:1px solid var(--line); overflow:hidden; padding:1.1rem 0; }
.marquee-track{ display:flex; gap:1.4rem; align-items:center; white-space:nowrap; font-family:var(--ff-serif); font-size:1.5rem; color:var(--ink); animation:marquee 28s linear infinite; }
.marquee-track i{ color:var(--blue); font-style:normal; } .marquee-track span{ opacity:.85; }
@keyframes marquee{ from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ---------- Sections ---------- */
.section{ padding:6.5rem 0; }
.section--tint{ background:var(--tint); }
.section-head{ max-width:46rem; margin:0 auto 3.5rem; text-align:center; }
.section-head--left{ margin-inline:0; text-align:left; }
.section-sub{ font-family:var(--ff-en); letter-spacing:.26em; font-size:.78rem; font-weight:600; color:var(--blue); margin-bottom:1rem; }
.section-sub--light{ color:var(--cyan); }
.section-title{ font-family:var(--ff-serif); font-weight:700; font-size:clamp(1.8rem,3.4vw,2.7rem); line-height:1.35; margin-bottom:1.2rem; }
.section-desc{ color:var(--ink-soft); font-size:1rem; }

/* ---------- Business grid ---------- */
.brand-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; }
.brand-card{ position:relative; background:#fff; border:1px solid var(--line); border-radius:4px; padding:1.8rem; display:flex; flex-direction:column; gap:1.1rem; transition:transform .28s ease, box-shadow .28s ease, border-color .28s ease; overflow:hidden; }
.brand-card:hover{ transform:translateY(-4px); box-shadow:0 22px 50px -28px rgba(10,58,120,.45); border-color:#cdd6e2; }
.brand-card-logo{ height:46px; display:flex; align-items:center; }
.brand-card-logo img{ height:100%; width:auto; object-fit:contain; }
.brand-card h3{ font-family:var(--ff-serif); font-size:1.2rem; font-weight:700; }
.brand-card p{ font-size:.9rem; color:var(--ink-soft); line-height:1.8; }
.brand-card-link{ margin-top:auto; font-weight:700; font-size:.88rem; color:var(--blue); }
.brand-card-kicker{ font-family:var(--ff-en); letter-spacing:.18em; font-size:.72rem !important; color:var(--cyan) !important; font-weight:600; }
.brand-card--feature{ border-color:var(--navy); border-width:1.5px; }
.brand-card-flag{ position:absolute; top:0; right:0; background:var(--navy); color:#fff; font-size:.72rem; font-weight:700; padding:.4em 1em; border-bottom-left-radius:4px; }
.brand-card--ec{ background:var(--navy); color:#fff; border-color:var(--navy); }
.brand-card--ec h3{ color:#fff; } .brand-card--ec p{ color:rgba(255,255,255,.8); } .brand-card--ec .brand-card-link{ color:var(--cyan); }

/* ---------- Reasons ---------- */
.reasons{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.4rem; }
.reason{ background:#fff; border:1px solid var(--line); border-radius:4px; padding:2rem 1.6rem; border-top:3px solid var(--navy); }
.reason-no{ font-family:var(--ff-en); font-weight:600; font-size:1.6rem; color:var(--blue); }
.reason h3{ font-family:var(--ff-serif); font-size:1.18rem; margin:.6rem 0 .8rem; }
.reason p{ font-size:.88rem; color:var(--ink-soft); }

/* ---------- Flow ---------- */
.flow{ list-style:none; display:grid; grid-template-columns:repeat(4,1fr); gap:1.2rem; }
.flow-step{ position:relative; padding:1.8rem 1.4rem; background:var(--tint); border-radius:4px; }
.flow-step::after{ content:"\2192"; position:absolute; right:-.85rem; top:50%; transform:translateY(-50%); color:var(--blue); font-weight:700; z-index:2; }
.flow-step:last-child::after{ display:none; }
.flow-no{ font-family:var(--ff-en); font-weight:600; font-size:.8rem; letter-spacing:.12em; color:var(--blue); }
.flow-step h3{ font-family:var(--ff-serif); font-size:1.1rem; margin:.5rem 0 .6rem; }
.flow-step p{ font-size:.85rem; color:var(--ink-soft); }

/* ---------- Message ---------- */
.message{ background:var(--navy); color:#fff; }
.message-inner{ text-align:center; max-width:50rem; }
.message .section-sub{ color:var(--cyan); }
.message-quote{ font-family:var(--ff-serif); font-weight:600; font-size:clamp(1.5rem,3vw,2.3rem); line-height:1.9; letter-spacing:.02em; }
.message-quote em{ color:var(--cyan); }
.message-by{ margin-top:2rem; font-size:.9rem; color:rgba(255,255,255,.7); letter-spacing:.05em; }

/* ---------- Company ---------- */
.company-grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:3.5rem; align-items:start; }
.company-table{ width:100%; border-collapse:collapse; }
.company-table th, .company-table td{ text-align:left; padding:1.1rem .4rem; border-bottom:1px solid var(--line); font-size:.95rem; vertical-align:top; }
.company-table th{ width:32%; font-weight:700; color:var(--navy); }
.company-table td{ color:var(--ink-soft); }

/* ---------- News ---------- */
.news-list{ list-style:none; border-top:1px solid var(--line); }
.news-list li{ display:flex; align-items:center; gap:1.4rem; padding:1.3rem .2rem; border-bottom:1px solid var(--line); flex-wrap:wrap; }
.news-list time{ font-family:var(--ff-en); color:var(--ink-soft); font-size:.9rem; }
.news-tag{ background:var(--tint); color:var(--navy); font-size:.75rem; font-weight:700; padding:.3em .9em; border-radius:2px; }
.news-list a{ font-weight:500; } .news-list a:hover{ color:var(--blue); }

/* ---------- Contact CTA ---------- */
.contact{ background:linear-gradient(135deg, rgba(10,58,120,.96), rgba(31,127,208,.92)),repeating-linear-gradient(45deg, rgba(255,255,255,.04) 0 18px, transparent 18px 36px); color:#fff; padding:6rem 0; text-align:center; }
.contact-title{ font-family:var(--ff-serif); font-size:clamp(1.8rem,4vw,2.8rem); margin-bottom:1.2rem; }
.contact-lead{ color:rgba(255,255,255,.85); margin-bottom:2.6rem; }
.contact-actions{ display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }

/* ---------- Footer ---------- */
.site-footer{ background:#0c1116; color:#aeb6c0; padding:4rem 0 0; }
.footer-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:2.5rem; padding-bottom:3rem; }
.footer-wordmark{ font-family:var(--ff-en); font-weight:600; font-size:1.7rem; letter-spacing:.14em; color:#fff; line-height:1; margin-bottom:1.2rem; }
.footer-wordmark span{ display:block; font-family:var(--ff-sans); font-size:.72rem; letter-spacing:.1em; color:#8a929c; margin-top:.5rem; font-weight:500; }
.footer-brand p{ font-size:.85rem; max-width:24em; line-height:1.9; }
.footer-nav h4{ color:#fff; font-size:.95rem; margin-bottom:1rem; }
.footer-nav a{ display:block; font-size:.85rem; padding:.3rem 0; color:#aeb6c0; }
.footer-nav a:hover{ color:#fff; }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.1); padding:1.5rem 0; }
.footer-bottom p{ text-align:center; font-size:.78rem; color:#6b757f; font-family:var(--ff-en); letter-spacing:.05em; }

/* ========================================================================
   Sub-pages (会社概要 / お問い合わせ / お知らせ / 投稿 など)
   ===================================================================== */
.page-main{ min-height:40vh; }
.page-hero{ background:var(--navy); color:#fff; padding:3.6rem 0; position:relative; overflow:hidden; }
.page-hero::after{ content:""; position:absolute; inset:0; background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px); background-size:42px 42px; opacity:.6; }
.page-hero .container{ position:relative; z-index:1; }
.page-hero-sub{ font-family:var(--ff-en); letter-spacing:.22em; font-size:.78rem; font-weight:600; color:var(--cyan); margin-bottom:.7rem; }
.page-hero-title{ font-family:var(--ff-serif); font-weight:700; font-size:clamp(1.7rem,3.6vw,2.6rem); }
.page-body{ padding:4rem auto; padding-top:4rem; padding-bottom:5rem; max-width:920px; }
.entry-content{ font-size:1rem; }
.entry-content > *{ margin-bottom:1.4rem; }
.entry-content h2{ font-family:var(--ff-serif); font-size:1.6rem; margin:2.4rem 0 1rem; padding-bottom:.5rem; border-bottom:2px solid var(--navy); }
.entry-content h3{ font-family:var(--ff-serif); font-size:1.25rem; margin:1.8rem 0 .8rem; color:var(--navy); }
.entry-content a{ color:var(--blue); text-decoration:underline; }
.entry-content ul, .entry-content ol{ padding-left:1.4em; }
.entry-content img{ border-radius:4px; }
.entry-content table{ width:100%; border-collapse:collapse; margin:1.4rem 0; }
.entry-content th, .entry-content td{ border:1px solid var(--line); padding:.9rem 1rem; text-align:left; }
.entry-content th{ background:var(--tint); color:var(--navy); font-weight:700; }
.back-link{ margin-top:2.5rem; }

/* Snow Monkey Blocks fallbacks (for legacy page content) */
.c-container{ width:90%; max-width:var(--maxw); margin-inline:auto; }
.u-slim-width{ max-width:760px; }
.smb-section{ padding:3rem 0; }
.smb-section__title{ font-family:var(--ff-serif); font-size:1.7rem; margin:.4rem 0 1rem; }
.smb-section__subtitle{ font-family:var(--ff-en); letter-spacing:.2em; font-size:.78rem; color:var(--blue); }
.smb-section__body{ font-size:1rem; }

/* Contact Form 7 — text-like fields only (must not catch button/submit/file) */
.wpcf7 input[type=text], .wpcf7 input[type=email], .wpcf7 input[type=tel],
.wpcf7 input[type=url], .wpcf7 input[type=number], .wpcf7 input[type=date],
.wpcf7 textarea, .wpcf7 select{
  width:100%; padding:.8em 1em; border:1px solid var(--line); border-radius:3px;
  font-family:inherit; font-size:1rem; background:#fff; margin-top:.3em;
}
.wpcf7 textarea{ min-height:9em; }
.wpcf7 .wpcf7-submit{
  background:var(--navy); color:#fff; border:none; padding:1em 2.6em; border-radius:2px;
  font-weight:700; font-size:1rem; cursor:pointer; transition:background .25s ease;
}
.wpcf7 .wpcf7-submit:hover{ background:var(--blue); }
.tablepress{ width:100%; border-collapse:collapse; }
.tablepress th, .tablepress td{ border:1px solid var(--line); padding:.8rem 1rem; }

/* ========================================================================
   Contact form (CF7 multi-step) — re-themed to navy
   ===================================================================== */
.wrap_contact{ max-width:760px; margin-inline:auto; }
.stepBar{ position:relative; list-style:none; margin:0 0 2.4em; padding:0; text-align:center; width:100%; overflow:hidden; display:flex; }
.stepBar .step{ position:relative; flex:1; line-height:44px; background:#eef1f5; color:var(--ink-soft); font-size:.9rem; font-weight:700; box-sizing:border-box; }
.stepBar .step:not(:last-child){ margin-right:6px; }
.stepBar .step::after{ content:""; position:absolute; right:-11px; top:0; width:0; height:0; border-style:solid; border-width:22px 0 22px 11px; border-color:transparent transparent transparent #eef1f5; z-index:2; }
.stepBar .step:not(:first-child)::before{ content:""; position:absolute; left:0; top:0; width:0; height:0; border-style:solid; border-width:22px 0 22px 11px; border-color:#eef1f5 #eef1f5 #eef1f5 #fff; z-index:1; }
.stepBar .step.current{ background:var(--navy); color:#fff; }
.stepBar .step.current::after{ border-left-color:var(--navy); }
.stepBar .step br{ display:none; }
h3.wpcf7c-elm-step1, h3.wpcf7c-elm-step2, h3.wpcf7c-elm-step3{ margin:0 0 2.2em; font-weight:500; font-size:.95rem; line-height:1.9; color:var(--ink-soft); background:var(--tint); padding:1.1em 1.3em; border-radius:4px; border-left:3px solid var(--navy); }

.tableFormat{ width:100%; }
.formInner .tableRow{ display:flex; flex-wrap:wrap; align-items:flex-start; border-bottom:1px solid var(--line); }
.formInner .leftBlock1{ width:34%; padding:1.4em .6em 1.4em .2em; position:relative; line-height:1.6; font-weight:700; }
.formInner .leftBlock1 label{ font-size:.98rem; }
.formInner .rightBlock1{ width:66%; padding:1.2em 0 1.3em 1.2em; }
.formInner .rightBlock1 p{ margin-bottom:.6em; }
.required{ display:inline-block; vertical-align:middle; margin-left:.5em; }
.required::before{ content:"必須"; background:#cc1f1f; color:#fff; font-size:.7rem; font-weight:700; letter-spacing:.1em; padding:.15em .7em; border-radius:3px; }

input.inputTextSingle1, textarea.inputAreaSize1, .wrap_contact input[type=text], .wrap_contact input[type=email], .wrap_contact textarea{
  width:100%; border:1px solid var(--line); border-radius:3px; padding:.7em .9em; font-family:inherit; font-size:1rem; box-sizing:border-box; background:#fff; transition:border-color .2s ease, box-shadow .2s ease;
}
.wrap_contact input[type=text]:focus, .wrap_contact input[type=email]:focus, .wrap_contact textarea:focus{ outline:none; border-color:var(--blue); box-shadow:0 0 0 3px rgba(31,127,208,.12); }
textarea.inputAreaSize1{ min-height:9em; }

/* File attachment field */
.fileField{ margin-bottom:.6em; }
.fileField input[type=file]{ width:100%; font-size:.92rem; padding:.6em; border:1px dashed #c3ccd8; border-radius:4px; background:var(--tint); cursor:pointer; box-sizing:border-box; }
.fileField input[type=file]::file-selector-button{ font-family:inherit; font-weight:700; border:none; background:var(--navy); color:#fff; padding:.5em 1.1em; border-radius:3px; margin-right:1em; cursor:pointer; }
.fileNote{ font-size:.8rem; color:var(--ink-soft); margin-top:.4em; line-height:1.7; }

.privacy{ width:100%; height:9em; overflow-y:auto; font-size:.82rem; line-height:1.8; margin:0 0 1em; background:#fff; border:1px solid var(--line); border-radius:4px; padding:1em; color:var(--ink-soft); }
.privacy a{ color:var(--blue); }
.wpcf7-acceptance{ font-weight:700; }

/* Buttons */
.wrap_contact .form_btn{ display:flex; justify-content:center; gap:1rem; flex-wrap:wrap; margin-top:1.5rem; }
.wrap_contact input[type=button].wpcf7-confirm,
.wrap_contact input[type=button].wpcf7-back,
.wrap_contact input[type=submit]{
  -webkit-appearance:none; appearance:none; background:var(--navy); color:#fff; min-width:240px; height:58px;
  font-size:1.05rem; font-weight:700; letter-spacing:.08em; border:0; border-radius:3px; cursor:pointer; outline:none;
  transition:background .25s ease, transform .25s ease;
}
.wrap_contact input[type=button].wpcf7-confirm:hover,
.wrap_contact input[type=submit]:hover{ background:var(--blue); transform:translateY(-2px); }
.wrap_contact input[type=button].wpcf7-back{ background:#6b757f; }
.wrap_contact input[type=button].wpcf7-back:hover{ background:#525b64; }
.wpcf7c-conf{ background:#f0f3f7 !important; border-color:var(--line) !important; }
input.wpcf7-confirm:disabled{ cursor:not-allowed; background:#c3ccd8 !important; }

/* CF7 validation / response */
.wpcf7-not-valid-tip{ color:#cc1f1f; font-size:.82rem; margin-top:.3em; }
.wpcf7-response-output{ border:1px solid var(--line) !important; border-radius:4px; padding:1em 1.2em !important; margin:1.5em 0 0 !important; font-size:.92rem; }
.wpcf7 form.invalid .wpcf7-response-output, .wpcf7 form.unaccepted .wpcf7-response-output{ border-color:#e7a6a6 !important; background:#fdf4f4; }
.wpcf7 form.sent .wpcf7-response-output{ border-color:#9fd0a8 !important; background:#f3faf4; }
.wpcf7-spinner{ margin:0 auto; }

@media (max-width:600px){
  .stepBar .step{ font-size:.78rem; line-height:1.4; padding:.6em 0; display:flex; align-items:center; justify-content:center; }
  .stepBar .step br{ display:block; }
  .formInner .tableRow{ flex-direction:column; }
  .formInner .leftBlock1, .formInner .rightBlock1{ width:100%; padding-left:0; padding-bottom:.3em; }
  .formInner .rightBlock1{ padding-top:.2em; padding-bottom:1.2em; }
  .wrap_contact input[type=button].wpcf7-confirm, .wrap_contact input[type=button].wpcf7-back, .wrap_contact input[type=submit]{ min-width:0; width:100%; }
}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .hero-grid{ grid-template-columns:1fr; gap:2.5rem; }
  .hero-visual{ aspect-ratio:16/10; max-width:520px; }
  .brand-grid{ grid-template-columns:repeat(2,1fr); }
  .reasons{ grid-template-columns:repeat(2,1fr); }
  .flow{ grid-template-columns:repeat(2,1fr); }
  .flow-step:nth-child(2)::after{ display:none; }
  .company-grid{ grid-template-columns:1fr; gap:2rem; }
}
@media (max-width:860px){
  .nav, .btn--cta{ display:none; }
  .nav-toggle{ display:flex; flex-direction:column; gap:5px; margin-left:auto; background:none; border:none; cursor:pointer; }
  .nav-toggle span{ width:26px; height:2px; background:var(--ink); display:block; }
  body.nav-open .nav{ display:flex; position:absolute; top:74px; left:0; right:0; flex-direction:column; background:#fff; padding:1.5rem 6%; gap:1.2rem; border-bottom:1px solid var(--line); }
  .section{ padding:4.5rem 0; }
  .brand-grid{ grid-template-columns:1fr; }
  .reasons{ grid-template-columns:1fr; }
  .flow{ grid-template-columns:1fr; }
  .flow-step::after{ display:none !important; }
  .hero-stats{ gap:1.6rem; }
  .hero-title{ font-size:2.2rem; }
}
