/* =========================================================
   LiFiNE（死後事務版）LP  —  style.css
   ========================================================= */

:root{
  --green-900:#1F5138;
  --green-700:#2E7350;
  --green-600:#3A8862;
  --green-500:#4F9E78;
  --green-300:#9FD3B4;
  --green-100:#E8F1EB;
  --green-50:#F2F8F4;
  --ink:#2A352E;
  --ink-soft:#5C6B62;
  --line:#E1EAE4;
  --bg:#FFFFFF;
  --bg-soft:#F6FAF7;
  --shadow-sm:0 1px 2px rgba(31,81,56,.06), 0 1px 8px rgba(31,81,56,.05);
  --shadow-md:0 6px 24px rgba(31,81,56,.10);
  --shadow-lg:0 18px 48px rgba(31,81,56,.16);
  --radius:14px;
  --radius-lg:20px;
  --maxw:1120px;
}

*,*::before,*::after{box-sizing:border-box;}
[hidden]{display:none!important;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:"Noto Sans JP",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.8;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
h1,h2,h3,p{margin:0;}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px;}
.container-narrow{max-width:820px;}
.pc-only{display:inline;}
.nowrap-pc{white-space:nowrap;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:inherit;font-weight:700;font-size:15px;line-height:1;
  padding:14px 22px;border-radius:999px;border:1.5px solid transparent;
  cursor:pointer;transition:transform .15s ease,box-shadow .2s ease,background .2s ease,color .2s ease;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px);}
.btn-sm{padding:10px 16px;font-size:14px;}
.btn-lg{padding:17px 30px;font-size:16px;}
.btn-block{width:100%;}
.btn-primary{background:var(--green-700);color:#fff;box-shadow:0 6px 16px rgba(46,115,80,.28);}
.btn-primary:hover{background:var(--green-900);box-shadow:0 10px 22px rgba(46,115,80,.34);}
.btn-outline{background:#fff;color:var(--green-700);border-color:var(--green-300);}
.btn-outline:hover{border-color:var(--green-700);background:var(--green-50);}
.btn-ghost{background:transparent;color:var(--green-700);border-color:transparent;}
.btn-ghost:hover{background:var(--green-50);}
.btn-text{background:transparent;color:var(--green-700);padding:6px 4px;border:none;text-decoration:underline;text-underline-offset:4px;}
.btn-text:hover{color:var(--green-900);}
.btn-line{background:#06C755;color:#fff;}
.btn-line:hover{background:#05b14c;}
.btn .arrow{font-weight:400;}
.btn-ico{font-size:1.1em;}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.9);backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid var(--line);
}
.header-inner{display:flex;align-items:center;gap:24px;height:72px;}
.brand{display:flex;align-items:center;gap:8px;flex-shrink:0;}
.brand-logo{display:inline-flex;}
.brand-name{font-weight:900;font-size:23px;letter-spacing:.02em;color:var(--green-900);}
.brand-badge{
  font-size:11px;font-weight:700;color:var(--green-700);
  background:var(--green-100);border:1px solid var(--green-300);
  padding:3px 8px;border-radius:6px;line-height:1;
}
.nav-links{display:flex;gap:28px;margin-left:8px;}
.nav-links a{font-size:14.5px;font-weight:500;color:var(--ink);transition:color .2s;}
.nav-links a:hover{color:var(--green-700);}
.header-actions{display:flex;align-items:center;gap:10px;margin-left:auto;}
.audience-link{display:inline-flex;align-items:center;gap:4px;font-size:13px;font-weight:700;
  color:var(--ink-soft);padding:8px 8px;border-radius:8px;transition:color .2s,background .2s;}
.audience-link:hover{color:var(--green-700);background:var(--green-50);}

.nav-toggle{display:none;flex-direction:column;gap:5px;width:42px;height:42px;
  align-items:center;justify-content:center;background:none;border:none;cursor:pointer;margin-left:auto;}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--green-900);border-radius:2px;transition:.25s;}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0;}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

.mobile-menu{
  display:flex;flex-direction:column;gap:4px;padding:12px 24px 22px;
  border-bottom:1px solid var(--line);background:#fff;
}
.mobile-menu a{padding:12px 4px;font-weight:500;border-bottom:1px solid var(--green-50);}
.mobile-menu .audience-link{padding:12px 4px;border-radius:0;color:var(--green-700);font-weight:700;}
.mobile-menu-actions{display:flex;flex-direction:column;gap:10px;margin-top:14px;}
.mobile-menu-actions .btn{width:100%;}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;background:
  radial-gradient(120% 90% at 85% -10%, var(--green-50) 0%, #fff 55%);
  padding:64px 0 72px;}
.hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;}
.hero-eyebrow{display:inline-block;font-size:13px;font-weight:700;color:var(--green-700);
  background:var(--green-100);padding:6px 15px;border-radius:999px;margin-bottom:18px;}
.hero-title{font-size:44px;font-weight:900;line-height:1.32;letter-spacing:.01em;color:var(--green-900);}
.hero-lead{margin-top:24px;font-size:16px;color:var(--ink-soft);}
.hero-qr{display:flex;align-items:center;gap:14px;margin-top:24px;}
.hero-qr-code{flex-shrink:0;display:inline-flex;padding:6px;background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow-sm);}
.hero-qr p{font-size:13.5px;color:var(--ink-soft);line-height:1.7;}
.hero-cta{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap;}
.hero-badges{display:flex;gap:10px;margin:34px 0 0;padding:0;list-style:none;flex-wrap:wrap;}
.hero-badges li{display:flex;align-items:center;gap:9px;}
.badge-ico{display:inline-flex;width:42px;height:42px;align-items:center;justify-content:center;
  background:var(--green-50);border:1px solid var(--green-100);border-radius:50%;flex-shrink:0;}
.hero-badges b{display:block;font-size:13px;font-weight:700;line-height:1.4;}
.hero-badges small{display:block;font-size:11px;color:var(--ink-soft);}

/* Leaf decorations */
.leaf-deco{position:absolute;border-radius:50%;pointer-events:none;z-index:0;}
.leaf-deco-1{top:-40px;right:-30px;width:220px;height:220px;
  background:radial-gradient(circle at 30% 30%, rgba(159,211,180,.45), transparent 65%);}
.leaf-deco-2{bottom:-60px;left:-50px;width:180px;height:180px;
  background:radial-gradient(circle at 60% 40%, rgba(79,158,120,.2), transparent 65%);}
.leaf-deco-3{top:-30px;right:8%;width:160px;height:160px;
  background:radial-gradient(circle at 40% 40%, rgba(255,255,255,.5), transparent 60%);}
.hero-inner,.cta-inner{position:relative;z-index:1;}

/* ---------- Hero mockups ---------- */
.hero-visual{position:relative;min-height:420px;}
.mock-dashboard{
  background:#fff;border:1px solid var(--line);border-radius:18px;
  box-shadow:var(--shadow-lg);overflow:hidden;width:96%;
}
.mock-bar{display:flex;align-items:center;gap:14px;padding:13px 18px;border-bottom:1px solid var(--green-50);}
.mock-brand{display:inline-flex;align-items:center;gap:5px;font-weight:900;color:var(--green-900);font-size:15px;}
.mock-bar-title{font-size:13px;color:var(--ink-soft);}
.mock-body{padding:18px;}
.mock-progress-card{background:var(--green-50);border-radius:12px;padding:16px;}
.mock-label{font-size:13px;font-weight:700;}
.mock-progress{display:flex;align-items:center;gap:18px;margin-top:10px;}
.ring{
  --p:38;width:74px;height:74px;border-radius:50%;flex-shrink:0;
  background:conic-gradient(var(--green-600) calc(var(--p)*1%), #DCEBE1 0);
  display:flex;align-items:center;justify-content:center;
}
.ring::before{content:"";position:absolute;width:54px;height:54px;background:var(--green-50);border-radius:50%;}
.ring span{position:relative;font-weight:900;font-size:21px;color:var(--green-900);}
.ring small{font-size:11px;font-weight:700;}
.mock-progress-meta{font-size:12.5px;color:var(--ink-soft);}
.mock-section-label{display:block;margin:18px 0 10px;font-size:12.5px;font-weight:700;color:var(--ink-soft);}
.mock-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:9px;}
.mock-tile{border:1px solid var(--line);border-radius:10px;padding:10px;display:flex;flex-direction:column;gap:5px;}
.mt-name{font-size:11.5px;font-weight:700;}
.mt-num{font-size:15px;font-weight:900;color:var(--green-900);}
.tag{font-size:9.5px;font-weight:700;padding:2px 7px;border-radius:5px;align-self:flex-start;}
.tag-go{background:var(--green-100);color:var(--green-700);}
.tag-wait{background:#F0EFEA;color:#8A8470;}

.mock-phone{
  position:absolute;right:-8px;bottom:-20px;width:172px;
  background:#1F2A24;border-radius:26px;padding:8px;box-shadow:var(--shadow-lg);
}
.mp-notch{width:54px;height:5px;background:#3a463f;border-radius:5px;margin:3px auto 7px;}
.mp-screen{background:var(--green-50);border-radius:18px;padding:12px;min-height:300px;}
.mp-head{display:flex;align-items:center;gap:4px;font-size:11px;font-weight:900;color:var(--green-900);}
.mp-bubble{background:#fff;border-radius:12px;border-top-left-radius:3px;padding:9px 11px;font-size:10.5px;
  line-height:1.6;margin:9px 0;box-shadow:var(--shadow-sm);}
.mp-btn{display:block;width:100%;background:var(--green-600);color:#fff;border:none;border-radius:8px;
  font-family:inherit;font-weight:700;font-size:11px;padding:8px;margin-bottom:10px;cursor:default;}
.mp-card{background:#fff;border-radius:10px;padding:10px;box-shadow:var(--shadow-sm);}
.mp-card-label{font-size:10px;font-weight:700;}
.mp-bar{height:7px;background:#DCEBE1;border-radius:4px;margin:6px 0 5px;overflow:hidden;}
.mp-bar i{display:block;height:100%;background:var(--green-600);border-radius:4px;}
.mp-card-meta{font-size:9.5px;color:var(--ink-soft);}
.mp-section{display:block;margin:11px 0 7px;font-size:10px;font-weight:700;color:var(--ink-soft);}
.mp-row{display:flex;align-items:center;gap:6px;background:#fff;border-radius:9px;padding:8px 10px;font-size:10.5px;
  font-weight:700;margin-bottom:6px;box-shadow:var(--shadow-sm);}
.mp-row small{margin-left:auto;font-weight:500;color:var(--ink-soft);font-size:9px;}
.dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.dot-go{background:var(--green-500);}
.dot-wait{background:#C9C3AE;}

/* ---------- Sections ---------- */
.section{padding:76px 0;}
.section-soft{background:var(--bg-soft);}
.section-title{
  text-align:center;font-size:30px;font-weight:900;color:var(--ink);
  margin-bottom:48px;line-height:1.5;letter-spacing:.01em;
}
.section-title-brand{color:var(--green-700);}
.brand-inline{color:var(--green-700);font-weight:900;letter-spacing:.02em;}

/* ---------- Card grids ---------- */
.cards-4{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
.cards-5{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;}
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:30px 22px;text-align:center;box-shadow:var(--shadow-sm);
  transition:transform .2s ease,box-shadow .2s ease;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
.card h3{font-size:17px;font-weight:700;margin:16px 0 12px;line-height:1.5;}
.card p{font-size:13.5px;color:var(--ink-soft);line-height:1.85;}
.card-ico{display:inline-flex;align-items:center;justify-content:center;width:80px;height:80px;
  background:var(--green-50);border-radius:50%;}

/* feature cards (brand-filled icon) */
.card-feature h3{font-size:16px;}
.feat-ico{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;
  background:var(--green-600);border-radius:16px;box-shadow:0 6px 14px rgba(46,115,80,.25);}
.card-merit .merit-ico{display:inline-flex;align-items:center;justify-content:center;width:78px;height:78px;
  background:var(--green-50);border-radius:50%;}

/* ---------- Flow ---------- */
.flow{display:flex;align-items:stretch;justify-content:center;gap:6px;flex-wrap:nowrap;}
.flow-step{flex:1;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:26px 16px;text-align:center;position:relative;box-shadow:var(--shadow-sm);}
.flow-num{position:absolute;top:-16px;left:50%;transform:translateX(-50%);
  width:32px;height:32px;border-radius:50%;background:var(--green-600);color:#fff;
  font-weight:900;font-size:15px;display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 10px rgba(46,115,80,.3);}
.flow-step h3{font-size:15px;font-weight:700;margin:14px 0 14px;line-height:1.45;}
.flow-ico{display:inline-flex;align-items:center;justify-content:center;width:72px;height:72px;
  background:var(--green-50);border-radius:50%;margin-bottom:12px;}
.flow-step p{font-size:12.5px;color:var(--ink-soft);line-height:1.8;}
.flow-arrow{align-self:center;color:var(--green-300);font-size:22px;font-weight:700;flex-shrink:0;}

/* ---------- OS concept ---------- */
.section-os{background:linear-gradient(180deg,#fff 0%,var(--green-50) 100%);}
.os-flow{display:flex;align-items:center;justify-content:center;gap:8px;}
.os-node{flex:1;max-width:230px;text-align:center;background:#fff;border:1px solid var(--line);
  border-radius:50%/12%;padding:30px 20px;box-shadow:var(--shadow-sm);}
.os-node{border-radius:var(--radius-lg);}
.os-circle{display:inline-flex;align-items:center;justify-content:center;width:84px;height:84px;
  border:2px solid var(--green-300);border-radius:50%;background:#fff;margin-bottom:14px;}
.os-circle-brand{background:var(--green-600);border-color:var(--green-600);}
.os-node h3{font-size:17px;font-weight:700;margin-bottom:10px;}
.os-node h3 small{font-size:12px;color:var(--ink-soft);font-weight:500;}
.os-node-center h3{color:var(--green-700);}
.os-node p{font-size:12.5px;color:var(--ink-soft);line-height:1.8;}
.os-link{color:var(--green-500);font-size:24px;flex-shrink:0;}

/* ---------- FAQ ---------- */
.faq{display:flex;flex-direction:column;gap:12px;}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden;box-shadow:var(--shadow-sm);}
.faq-item summary{display:flex;align-items:center;gap:14px;padding:18px 22px;cursor:pointer;
  list-style:none;font-weight:700;font-size:15.5px;}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-q{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;flex-shrink:0;
  background:var(--green-100);color:var(--green-700);border-radius:6px;font-weight:900;font-size:14px;}
.faq-question{flex:1;}
.faq-chev{color:var(--green-500);font-size:20px;transition:transform .25s ease;flex-shrink:0;}
.faq-item[open] .faq-chev{transform:rotate(180deg);}
.faq-answer{padding:0 22px 20px 62px;font-size:14px;color:var(--ink-soft);line-height:1.9;}

/* ---------- Final CTA ---------- */
.cta{position:relative;overflow:hidden;background:linear-gradient(120deg,var(--green-50),var(--green-100));
  padding:60px 0;}
.cta-inner{display:flex;align-items:center;justify-content:space-between;gap:40px;}
.cta-copy h2{font-size:34px;font-weight:900;color:var(--green-900);line-height:1.4;}
.cta-copy p{margin-top:18px;font-size:15.5px;color:var(--ink-soft);}
.cta-actions{display:flex;gap:14px;margin-top:28px;flex-wrap:wrap;}
.cta-actions-sub{margin-top:14px;}
.cta-photo-inner{width:200px;height:200px;border-radius:50%;background:#fff;border:6px solid #fff;
  box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:center;overflow:hidden;}

/* ---------- Footer ---------- */
.site-footer{background:var(--green-900);color:#fff;padding:40px 0;}
.footer-inner{display:flex;align-items:center;gap:30px;flex-wrap:wrap;}
.brand-footer .brand-name{color:#fff;}
.brand-footer .brand-badge{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.25);}
.footer-links{display:flex;gap:26px;margin-left:20px;}
.footer-links a{font-size:14px;color:rgba(255,255,255,.85);transition:color .2s;}
.footer-links a:hover{color:#fff;}
.copyright{margin-left:auto;font-size:13px;color:rgba(255,255,255,.6);}

/* ---------- Problem illustrations (B2C) ---------- */
.problem-illust{width:100%;height:96px;margin-bottom:14px;display:flex;align-items:flex-end;justify-content:center;}
.problem-illust svg{height:96px;width:auto;}

/* ---------- Reassurance (3つの安心) ---------- */
.reassure-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.reassure-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .2s ease;}
.reassure-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
.reassure-illust{background:var(--green-50);height:150px;display:flex;align-items:center;justify-content:center;padding:18px;}
.reassure-illust svg{width:100%;height:100%;max-width:230px;}
.reassure-body{padding:24px 24px 28px;}
.reassure-body h3{font-size:17px;font-weight:700;margin-bottom:12px;line-height:1.5;}
.reassure-body p{font-size:13.5px;color:var(--ink-soft);line-height:1.85;}

/* ---------- Use cases (活用シーン) ---------- */
.section-sub{text-align:center;font-size:15px;color:var(--ink-soft);margin:-32px 0 42px;}
.cases-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;}
.case-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:26px 26px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;align-items:flex-start;
  gap:13px;transition:transform .2s ease,box-shadow .2s ease;}
.case-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
.case-tag{display:inline-flex;align-items:center;gap:7px;background:var(--green-100);color:var(--green-700);
  font-weight:700;font-size:13.5px;padding:7px 15px;border-radius:999px;}
.case-block{display:flex;gap:11px;width:100%;}
.case-label{flex:0 0 auto;font-size:11px;font-weight:700;padding:3px 9px;border-radius:6px;margin-top:3px;white-space:nowrap;}
.case-label-when{background:#F1EFE8;color:#897F62;}
.case-label-on{background:var(--green-600);color:#fff;}
.case-block p{margin:0;font-size:14px;line-height:1.85;}
.case-when p{color:var(--ink-soft);}
.case-on p{color:var(--ink);}
.case-arrow{align-self:center;line-height:0;}
.cases-note{text-align:center;font-size:12.5px;color:var(--ink-soft);margin-top:30px;}

/* ---------- Company ---------- */
.company-lead{text-align:center;font-size:15px;color:var(--ink-soft);margin:-24px 0 36px;}
.company-table{max-width:660px;margin:0 auto;border-top:1px solid var(--line);}
.company-row{display:flex;gap:24px;padding:18px 8px;border-bottom:1px solid var(--line);}
.company-row dt{flex:0 0 150px;font-weight:700;font-size:14.5px;color:var(--green-900);}
.company-row dd{flex:1;margin:0;font-size:14.5px;color:var(--ink);line-height:1.85;}
.company-note{display:inline-block;margin-left:8px;font-size:12.5px;color:var(--ink-soft);}

/* ---------- Contact (資料請求フォーム + 導入相談) ---------- */
.contact{position:relative;overflow:hidden;background:linear-gradient(120deg,var(--green-50),var(--green-100));padding:74px 0;}
.contact .section-sub{margin:-34px 0 40px;}
.contact-grid{display:grid;grid-template-columns:1.55fr 1fr;gap:24px;align-items:stretch;max-width:980px;margin:0 auto;}
.contact-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:32px;box-shadow:var(--shadow-md);}
.contact-h{display:flex;align-items:center;gap:9px;font-size:18px;font-weight:700;color:var(--green-900);margin-bottom:22px;}
.contact-h-ico{font-size:1.1em;}
.lead-form{display:flex;flex-direction:column;gap:16px;}
.field-row{display:flex;gap:16px;}
.field-row .field{flex:1;min-width:0;}
.lead-form .field{display:flex;flex-direction:column;gap:7px;}
.lead-form .field span{font-size:13px;font-weight:700;display:flex;align-items:center;gap:8px;}
.req{font-size:10px;font-weight:700;color:#fff;background:var(--green-600);padding:2px 7px;border-radius:5px;line-height:1.4;}
.lead-form input,.lead-form select,.lead-form textarea{font-family:inherit;font-size:15px;padding:12px 14px;
  border:1.5px solid var(--line);border-radius:10px;background:#fff;width:100%;transition:border .2s,box-shadow .2s;}
.lead-form textarea{resize:vertical;}
.lead-form input:focus,.lead-form select:focus,.lead-form textarea:focus{outline:none;border-color:var(--green-500);box-shadow:0 0 0 3px rgba(79,158,120,.18);}
.form-note{font-size:11.5px;color:var(--ink-soft);margin-top:2px;line-height:1.7;}
.contact-side{display:flex;flex-direction:column;}
.contact-side-lead{font-size:13.5px;color:var(--ink-soft);line-height:1.85;margin-bottom:20px;}
.contact-tel{display:flex;align-items:center;gap:12px;color:var(--green-700);padding:16px 18px;
  border:1.5px solid var(--green-300);border-radius:12px;background:var(--green-50);transition:.2s;}
.contact-tel:hover{border-color:var(--green-700);background:var(--green-100);}
.contact-tel small{display:block;font-size:11px;color:var(--ink-soft);font-weight:700;}
.contact-tel b{display:block;font-size:23px;font-weight:900;letter-spacing:.02em;color:var(--green-900);}
.contact-mail{margin-top:12px;}
.contact-mail b{font-size:17px;}
.contact-hours{font-size:12.5px;color:var(--ink-soft);margin-top:12px;}
.contact-switch{margin-top:auto;padding-top:20px;align-self:flex-start;}
.contact-disclaimer{text-align:center;font-size:12px;color:var(--ink-soft);margin-top:26px;}

/* ---------- Pre-launch notice (公開前モード) ---------- */
.hero-prelaunch{margin-top:18px;font-size:13.5px;color:var(--ink-soft);background:var(--green-50);
  border:1px solid var(--green-100);border-radius:10px;padding:11px 15px;line-height:1.7;}
.hero-prelaunch b{color:var(--green-700);font-weight:700;}
.cta-prelaunch{margin-top:14px;font-size:13px;color:var(--ink-soft);}

/* ---------- Legal (privacy policy) ---------- */
.legal{padding:56px 0 72px;}
.legal-lead{font-size:14.5px;color:var(--ink-soft);line-height:1.95;margin-bottom:8px;}
.legal-section{margin-top:34px;}
.legal-section h2{font-size:18px;font-weight:700;color:var(--green-900);margin-bottom:14px;
  padding-bottom:9px;border-bottom:2px solid var(--green-100);}
.legal-section p{font-size:14.5px;color:var(--ink);line-height:1.95;}
.legal-section ul{margin:10px 0 0;padding-left:1.25em;}
.legal-section li{font-size:14.5px;color:var(--ink);line-height:1.9;margin-bottom:4px;}
.legal-contact{background:var(--green-50);border:1px solid var(--green-100);border-radius:12px;padding:20px 24px;margin-top:14px;}
.legal-contact p{margin:3px 0;font-size:14px;line-height:1.8;}
.legal-meta{margin-top:42px;font-size:13.5px;color:var(--ink-soft);text-align:right;line-height:1.9;}
.legal-back{display:inline-flex;align-items:center;gap:5px;margin-top:40px;font-weight:700;color:var(--green-700);}
.legal-back:hover{color:var(--green-900);}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease;}
.reveal.is-visible{opacity:1;transform:none;}

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width:1024px){
  .hero-title{font-size:38px;}
  .cards-5{grid-template-columns:repeat(3,1fr);}
  .cards-5 .card:nth-child(4),.cards-5 .card:nth-child(5){grid-column:span 1;}
  .flow{flex-wrap:wrap;}
  .flow-arrow{display:none;}
  .flow-step{flex:1 1 30%;min-width:160px;}
  .os-flow{flex-wrap:wrap;}
  .os-link{transform:rotate(90deg);}
  .os-node{flex:1 1 40%;}
}

@media (max-width:860px){
  .nav-links{display:none;}
  .header-actions{display:none;}
  .nav-toggle{display:flex;}
  .hero-inner{grid-template-columns:1fr;gap:56px;}
  .hero-visual{margin:0 auto;max-width:460px;width:100%;}
  .cards-4{grid-template-columns:repeat(2,1fr);}
  .cta-inner{flex-direction:column;text-align:center;}
  .cta-actions,.cta-actions-sub{justify-content:center;}
  .cta-photo{order:-1;}
  .contact-grid{grid-template-columns:1fr;}
}

@media (max-width:560px){
  .container{padding:0 18px;}
  .hero{padding:40px 0 52px;}
  .hero-title{font-size:30px;line-height:1.4;}
  .hero-lead br,.pc-only{display:none;}
  .hero-cta{flex-direction:column;}
  .hero-cta .btn{width:100%;}
  .hero-badges{flex-direction:column;gap:14px;}
  .hero-badges li{width:100%;}
  .section{padding:54px 0;}
  .section-title{font-size:23px;margin-bottom:34px;}
  .cards-4,.cards-5{grid-template-columns:1fr;}
  .cases-grid{grid-template-columns:1fr;}
  .field-row{flex-direction:column;gap:16px;}
  .contact-card{padding:24px;}
  .flow-step{flex:1 1 100%;}
  .os-node{flex:1 1 100%;max-width:none;}
  .cta-copy h2{font-size:26px;}
  .footer-inner{flex-direction:column;align-items:flex-start;gap:18px;}
  .footer-links{margin-left:0;flex-wrap:wrap;gap:16px;}
  .copyright{margin-left:0;}
  .mock-phone{display:none;}
  .mock-dashboard{width:100%;}
  .company-lead{margin:-14px 0 26px;}
  .company-row{flex-direction:column;gap:4px;padding:14px 4px;}
  .company-row dt{flex:none;font-size:13px;color:var(--green-700);}
  .section-sub{margin:-22px 0 30px;}
}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important;}
  .reveal{opacity:1;transform:none;}
}
