/*
Theme Name: MEMORABLE
Theme URI: https://example.com/
Author: 株式会社メモラブル
Author URI: https://example.com/
Description: 株式会社メモラブルのコーポレートサイト用WordPressテーマ。衛生用品の生産・海外商品調達・防虫抗菌施工を紹介する、鮮やかなグリーン基調の1ページ構成テーマです。
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: memorable
*/

/*
Theme Name: MEMORABLE
Theme URI: https://example.com/
Author: 株式会社メモラブル
Author URI: https://example.com/
Description: 株式会社メモラブルのコーポレートサイト用WordPressテーマ。衛生用品の生産・海外商品調達・防虫抗菌施工を紹介する、柔らかいセージグリーン基調・明朝見出しの1ページ構成テーマです。
Version: 1.2.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: memorable
*/

/* =========================================================
   株式会社メモラブル — コーポレートサイト
   テーマカラー: 柔らかいセージグリーン / 明朝見出しの上品な法人向けデザイン
   ========================================================= */

:root{
  --ink:#2f3a34;            /* やや柔らかい黒 */
  --ink-soft:#56635c;
  --muted:#869089;
  --line:#e7ede8;
  --line-soft:#f0f4f1;
  --bg:#ffffff;
  --bg-soft:#f4f8f5;        /* ほんのり緑のオフホワイト */
  --bg-mint:#e9f2ec;        /* 淡いミント */

  --green:#5fae7f;          /* 柔らかいセージグリーン（メイン） */
  --green-hover:#4f9b6e;
  --green-bright:#86c79f;   /* 明るい淡グリーン・アクセント */
  --green-ink:#3d7a55;      /* 文字用の落ち着いたグリーン */
  --green-deep:#456b56;     /* ヒーロー・フッター（深すぎない緑灰） */
  --green-deeper:#3a5b49;

  --shadow-sm:0 4px 14px rgba(60,90,72,.06);
  --shadow-md:0 14px 32px rgba(60,90,72,.09);
  --shadow-lg:0 24px 56px rgba(60,90,72,.13);

  /* フォント：見出しは明朝体、本文はゴシック（可読性重視） */
  --font-jp:"Zen Kaku Gothic New","Hiragino Kaku Gothic ProN","Noto Sans JP",sans-serif;
  --font-mincho:"Shippori Mincho","Hiragino Mincho ProN","Yu Mincho","YuMincho",serif;
  --font-lat:"Outfit","Zen Kaku Gothic New",sans-serif;

  --radius:18px;
  --radius-sm:13px;
  --header-h:74px;
  --container:1180px;
}

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

html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}

body{
  font-family:var(--font-jp);
  color:var(--ink);
  background:var(--bg);
  line-height:1.85;
  font-size:16px;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
ul{list-style:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;}

section{scroll-margin-top:96px;}

/* ---------- layout helpers ---------- */
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 26px;}
.section{padding:108px 0;}
.section--soft{background:var(--bg-soft);}
.section--tight{padding-top:78px;}

/* ---------- section heading ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:11px;
  font-family:var(--font-lat);
  font-size:.78rem;font-weight:600;letter-spacing:.16em;
  text-transform:uppercase;color:var(--green-ink);
  margin-bottom:14px;
}
.eyebrow::before{
  content:"";width:30px;height:2px;border-radius:2px;
  background:linear-gradient(90deg,var(--green),var(--green-bright));
}
.eyebrow--light{color:#c8e4d2;}
.eyebrow--light::before{background:linear-gradient(90deg,var(--green-bright),#c8e4d2);}

.s-head{margin-bottom:54px;}
.s-title{
  font-family:var(--font-mincho);
  font-size:clamp(1.9rem,3.7vw,2.75rem);
  font-weight:800;line-height:1.4;letter-spacing:.02em;
  color:var(--ink);
}
.s-title .accent{color:var(--green-ink);}
.s-lead{
  margin-top:18px;font-size:1.02rem;color:var(--ink-soft);
  line-height:1.95;
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-weight:700;font-size:.97rem;
  padding:15px 28px;border-radius:999px;
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease;
  white-space:nowrap;
}
.btn svg{width:17px;height:17px;transition:transform .25s ease;}
.btn:hover svg{transform:translateX(3px);}
.btn--primary{
  background:linear-gradient(135deg,var(--green),var(--green-hover));
  color:#fff;box-shadow:0 12px 26px rgba(95,174,127,.34);
}
.btn--primary:hover{transform:translateY(-3px);box-shadow:0 18px 34px rgba(95,174,127,.44);}
.btn--ghost{
  background:rgba(255,255,255,.06);color:#fff;
  border:1.5px solid rgba(255,255,255,.4);
}
.btn--ghost:hover{background:rgba(255,255,255,.14);transform:translateY(-3px);}
.btn--dark{
  background:var(--green-deep);color:#fff;
}
.btn--dark:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);background:var(--green-ink);}

/* =========================================================
   HEADER
   ========================================================= */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  height:var(--header-h);
  background:rgba(255,255,255,.86);
  backdrop-filter:blur(12px);
  border-bottom:1px solid transparent;
  transition:box-shadow .3s ease, border-color .3s ease, background .3s ease;
}
.site-header.scrolled{
  box-shadow:0 6px 22px rgba(13,60,40,.08);
  border-bottom-color:var(--line);
  background:rgba(255,255,255,.95);
}
.header-inner{
  height:100%;display:flex;align-items:center;justify-content:space-between;
}
.brand{display:flex;align-items:baseline;gap:10px;}
.brand__mark{
  font-family:var(--font-lat);font-weight:700;
  font-size:1.32rem;letter-spacing:.04em;color:var(--green-ink);
}
.brand__mark .dot{color:var(--green);}
.brand__name{font-size:.83rem;color:var(--muted);font-weight:500;}

.nav{display:flex;align-items:center;gap:4px;}
.nav a{
  font-size:.93rem;font-weight:500;color:var(--ink-soft);
  padding:9px 14px;border-radius:9px;transition:color .2s ease,background .2s ease;
}
.nav a:hover{color:var(--green-ink);background:var(--bg-mint);}
.nav .nav-cta{
  margin-left:8px;background:var(--green);color:#fff;font-weight:700;
  padding:10px 20px;border-radius:999px;
}
.nav .nav-cta:hover{background:var(--green-hover);color:#fff;}

.burger{
  display:none;width:44px;height:44px;border-radius:11px;
  background:var(--bg-mint);position:relative;
}
.burger span{
  position:absolute;left:12px;right:12px;height:2.4px;border-radius:2px;
  background:var(--green-ink);transition:transform .3s ease,opacity .2s ease;
}
.burger span:nth-child(1){top:15px;}
.burger span:nth-child(2){top:21px;}
.burger span:nth-child(3){top:27px;}
.burger.open span:nth-child(1){transform:translateY(6px) rotate(45deg);}
.burger.open span:nth-child(2){opacity:0;}
.burger.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg);}

/* mobile slide menu */
.mobile-nav{
  position:fixed;top:var(--header-h);left:0;right:0;z-index:99;
  background:#fff;border-bottom:1px solid var(--line);
  box-shadow:var(--shadow-md);
  transform:translateY(-130%);transition:transform .38s cubic-bezier(.4,0,.2,1);
  padding:14px 26px 26px;
}
.mobile-nav.open{transform:translateY(0);}
.mobile-nav a{
  display:block;padding:15px 6px;font-size:1.02rem;font-weight:500;
  border-bottom:1px solid var(--line-soft);color:var(--ink);
}
.mobile-nav a:last-child{border-bottom:none;}
.mobile-nav .m-cta{
  margin-top:16px;text-align:center;background:var(--green);color:#fff;
  font-weight:700;border-radius:999px;border-bottom:none;
}

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative;overflow:hidden;color:#fff;
  padding:calc(var(--header-h) + 86px) 0 110px;
  background:
    radial-gradient(90% 70% at 12% 8%, #b6dd8e 0%, transparent 55%),
    radial-gradient(85% 80% at 92% 18%, #7fcfb4 0%, transparent 58%),
    radial-gradient(120% 90% at 70% 100%, #3f8f8c 0%, transparent 60%),
    linear-gradient(150deg,#8fc98e 0%,#5fae9a 50%,#3f7d82 100%);
}
/* 背景イメージ風：やわらかな光のテクスチャ */
.hero::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:
    radial-gradient(rgba(255,255,255,.07) 1px,transparent 1.6px),
    radial-gradient(60% 50% at 25% 30%,rgba(255,255,255,.14) 0%,transparent 60%);
  background-size:30px 30px, auto;
  opacity:.9;
}
.hero::after{
  content:"";position:absolute;width:600px;height:600px;
  right:-180px;top:-160px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.3) 0%,transparent 70%);
  filter:blur(30px);pointer-events:none;
}
.hero-grid{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1.04fr .96fr;gap:58px;align-items:center;
}
.hero-copy .eyebrow{margin-bottom:20px;}
.hero h1{
  font-family:var(--font-mincho);
  font-size:clamp(1.95rem,4.4vw,3.05rem);
  font-weight:800;line-height:1.5;letter-spacing:.015em;
  text-shadow:0 2px 16px rgba(45,70,58,.28);
}
.hero h1 .hl{
  color:#fbffe9;
  position:relative;white-space:nowrap;
}
.hero h1 .hl::after{
  content:"";position:absolute;left:0;right:0;bottom:.04em;height:.14em;
  background:rgba(255,255,255,.4);border-radius:3px;z-index:-1;
}
.hero p.lead{
  margin-top:22px;font-size:1.06rem;line-height:1.95;
  color:rgba(255,255,255,.94);max-width:480px;
  text-shadow:0 1px 10px rgba(45,70,58,.25);
}
.hero-actions{display:flex;gap:14px;margin-top:32px;flex-wrap:wrap;}

/* video placeholder */
.video-ph{
  position:relative;aspect-ratio:16/9;border-radius:20px;overflow:hidden;
  background:linear-gradient(150deg,#4f8a82,#3f7d82);
  border:1px solid rgba(255,255,255,.28);
  box-shadow:var(--shadow-lg);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;
}
.video-ph::before{
  content:"";position:absolute;inset:0;
  background-image:linear-gradient(135deg,rgba(134,199,159,.12) 0%,transparent 60%);
}
.video-ph__btn{
  width:74px;height:74px;border-radius:50%;
  background:rgba(255,255,255,.95);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 0 0 rgba(255,255,255,.4);
  animation:pulse 2.6s infinite;
}
.video-ph__btn svg{width:26px;height:26px;margin-left:4px;fill:var(--green-ink);}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(255,255,255,.34);}
  70%{box-shadow:0 0 0 22px rgba(255,255,255,0);}
  100%{box-shadow:0 0 0 0 rgba(255,255,255,0);}
}
.video-ph__txt{
  font-family:var(--font-lat);font-weight:600;letter-spacing:.06em;
  font-size:.92rem;color:rgba(255,255,255,.92);
}
.video-ph__note{
  font-size:.76rem;color:rgba(255,255,255,.5);
}

/* hero stat strip */
.hero-strip{
  position:relative;z-index:2;margin-top:62px;
  display:grid;grid-template-columns:repeat(3,1fr);
  border-top:1px solid rgba(255,255,255,.28);
}
.hero-strip div{
  padding:26px 8px 4px;
}
.hero-strip dt{
  font-family:var(--font-lat);font-size:.74rem;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.78);
}
.hero-strip dd{
  margin-top:6px;font-size:1.04rem;font-weight:700;color:#fff;
}

/* =========================================================
   BUSINESS (事業内容)
   ========================================================= */
.biz-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:26px;
}
.biz-card{
  position:relative;overflow:hidden;
  background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);padding:38px 32px 34px;
  box-shadow:var(--shadow-sm);
  transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;
}
.biz-card:hover{transform:translateY(-7px);box-shadow:var(--shadow-md);border-color:#cde6d6;}
.biz-card__num{
  position:absolute;top:18px;right:24px;
  font-family:var(--font-lat);font-size:3.1rem;font-weight:700;
  color:var(--bg-mint);line-height:1;
}
.biz-card__icon{
  width:58px;height:58px;border-radius:15px;
  background:linear-gradient(140deg,var(--green),var(--green-bright));
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 20px rgba(95,174,127,.30);
}
.biz-card__icon svg{width:28px;height:28px;stroke:#fff;}
.biz-card h3{
  font-family:var(--font-mincho);
  margin-top:22px;font-size:1.34rem;font-weight:700;letter-spacing:.03em;
}
.biz-card h3 small{
  display:block;font-family:var(--font-lat);font-weight:600;
  font-size:.72rem;letter-spacing:.1em;color:var(--green-ink);
  text-transform:uppercase;margin-bottom:6px;
}
.biz-card p{margin-top:12px;font-size:.95rem;color:var(--ink-soft);}

/* =========================================================
   PRODUCTS (主力商品)
   ========================================================= */
.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;}
.prod-card{
  position:relative;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow-sm);
  transition:transform .3s ease,box-shadow .3s ease;
  display:flex;flex-direction:column;
}
.prod-card:hover{transform:translateY(-7px);box-shadow:var(--shadow-md);}
.prod-card.is-feature{border-color:var(--green);box-shadow:0 14px 34px rgba(95,174,127,.18);}
.prod-card__body{padding:24px 26px 28px;flex:1;display:flex;flex-direction:column;}
/* 「主力商品」バッジ：画像の左上にオーバーレイ表示 */
.prod-flag{
  position:absolute;top:14px;left:14px;z-index:3;
  font-size:.72rem;font-weight:700;letter-spacing:.04em;
  color:#fff;background:var(--green);
  padding:6px 13px;border-radius:999px;
  box-shadow:0 4px 12px rgba(58,91,73,.32);
}
.prod-card h3{font-family:var(--font-mincho);font-size:1.24rem;font-weight:700;letter-spacing:.03em;}
.prod-card p{margin-top:10px;font-size:.92rem;color:var(--ink-soft);flex:1;}
.prod-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px;}
.prod-tags span{
  font-size:.78rem;font-weight:600;color:var(--green-ink);
  background:var(--bg-mint);border-radius:8px;padding:6px 11px;
}

/* =========================================================
   IMAGE PLACEHOLDER (共通)
   ========================================================= */
.ph{
  position:relative;width:100%;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:9px;text-align:center;padding:22px;
  background:
    repeating-linear-gradient(45deg,rgba(95,174,127,.06) 0 13px,rgba(95,174,127,.11) 13px 26px),
    var(--bg-mint);
  border:1.5px dashed rgba(95,174,127,.45);
  color:var(--green-ink);
}
.ph--4x3{aspect-ratio:4/3;}
.ph--16x9{aspect-ratio:16/9;}
.ph--1x1{aspect-ratio:1/1;}
.ph--wide{aspect-ratio:3/2;}
.ph__ic{width:38px;height:38px;stroke:var(--green);opacity:.85;}
.ph__txt{font-size:.95rem;font-weight:700;letter-spacing:.02em;}
.ph__sub{font-size:.74rem;color:var(--muted);font-weight:500;}

/* --- 画像が入った場合：プレースホルダー装飾を解除し画像をフィット --- */
.ph:has(img){
  display:block;padding:0;border:none;background:none;overflow:hidden;
}
.ph img{
  width:100%;height:100%;display:block;
  object-fit:cover;object-position:center;
  transition:transform .55s ease;
}
/* 商品ラインナップ（白背景の切り抜き商品写真）は全体を見せる */
.lineup-card .ph:has(img){background:#ffffff;}
.lineup-card .ph img{object-fit:contain;padding:16px;}
/* ホバー時のさりげない拡大演出 */
.prod-card:hover .ph img,
.split:hover .ph img{transform:scale(1.045);}
.lineup-card:hover .ph img{transform:scale(1.05);}

/* =========================================================
   CAPABILITY (生産対応内容)
   ========================================================= */
.cap-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;
}
.cap-item{
  display:flex;align-items:center;gap:14px;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:20px 22px;box-shadow:var(--shadow-sm);
  transition:transform .25s ease,border-color .25s ease;
}
.cap-item:hover{transform:translateY(-4px);border-color:#cce5d4;}
.cap-check{
  flex-shrink:0;width:34px;height:34px;border-radius:50%;
  background:linear-gradient(140deg,var(--green),var(--green-bright));
  display:flex;align-items:center;justify-content:center;
}
.cap-check svg{width:17px;height:17px;stroke:#fff;stroke-width:3;}
.cap-item span{font-weight:700;font-size:1rem;}

/* =========================================================
   FLOW (生産フロー)
   ========================================================= */
.flow{
  display:grid;grid-template-columns:repeat(6,1fr);gap:14px;
}
.flow-step{
  position:relative;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius-sm);padding:26px 16px 22px;text-align:center;
  box-shadow:var(--shadow-sm);
}
.flow-step::after{
  content:"";position:absolute;right:-11px;top:50%;z-index:2;
  width:20px;height:20px;transform:translateY(-50%) rotate(45deg);
  border-top:2px solid var(--green);border-right:2px solid var(--green);
  background:var(--bg-soft);
}
.flow-step:last-child::after{display:none;}
.flow-num{
  width:46px;height:46px;margin:0 auto 14px;border-radius:50%;
  background:linear-gradient(140deg,var(--green-deep),var(--green-ink));
  color:#fff;font-family:var(--font-lat);font-weight:700;font-size:1.15rem;
  display:flex;align-items:center;justify-content:center;
}
.flow-step h4{font-size:1.02rem;font-weight:700;}
.flow-step p{margin-top:7px;font-size:.81rem;color:var(--muted);line-height:1.7;}

/* =========================================================
   LINEUP (マスク展開例)
   ========================================================= */
.lineup-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.lineup-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow-sm);
  transition:transform .3s ease,box-shadow .3s ease;
}
.lineup-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);}
.lineup-card__cap{padding:16px 18px 18px;}
.lineup-card__cap h4{font-size:1.04rem;font-weight:700;}
.lineup-card__cap p{font-size:.82rem;color:var(--muted);margin-top:4px;}

/* =========================================================
   SPLIT (実績 / 海外調達 / 防虫抗菌)
   ========================================================= */
.split{
  display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center;
  background:#fff;border:1px solid var(--line);border-radius:24px;
  padding:42px;box-shadow:var(--shadow-sm);
}
.split--rev .split__media{order:2;}
.split--rev .split__text{order:1;}
.split__text h3{font-family:var(--font-mincho);font-size:1.5rem;font-weight:800;line-height:1.55;letter-spacing:.03em;}
.split__text h3 small{
  display:block;font-family:var(--font-lat);font-weight:600;
  font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--green-ink);margin-bottom:8px;
}
.split__text p{margin-top:16px;font-size:.98rem;color:var(--ink-soft);}
.split__list{margin-top:20px;display:flex;flex-direction:column;gap:10px;}
.split__list li{
  display:flex;align-items:flex-start;gap:10px;font-size:.94rem;font-weight:500;
}
.split__list li svg{
  flex-shrink:0;width:20px;height:20px;stroke:var(--green);stroke-width:2.6;margin-top:3px;
}
.media-note{margin-top:10px;font-size:.76rem;color:var(--muted);text-align:center;}

.split-stack{display:flex;flex-direction:column;gap:30px;}

/* =========================================================
   COMPANY (会社概要)
   ========================================================= */
.company-card{
  background:#fff;border:1px solid var(--line);border-radius:24px;
  box-shadow:var(--shadow-sm);overflow:hidden;
}
.company-row{
  display:grid;grid-template-columns:200px 1fr;
  border-bottom:1px solid var(--line-soft);
}
.company-row:last-child{border-bottom:none;}
.company-row dt{
  padding:22px 28px;font-weight:700;font-size:.95rem;
  background:var(--bg-soft);color:var(--green-ink);
  display:flex;align-items:center;
}
.company-row dd{padding:22px 28px;font-size:.97rem;color:var(--ink-soft);}
.company-row dd a{color:var(--green-ink);font-weight:600;border-bottom:1px solid currentColor;}

/* =========================================================
   CONTACT (お問い合わせ)
   ========================================================= */
.contact-wrap{
  display:grid;grid-template-columns:.85fr 1.15fr;gap:40px;align-items:start;
}
.contact-aside{
  background:linear-gradient(160deg,var(--green-deep),var(--green-deeper));
  color:#fff;border-radius:24px;padding:40px 36px;
  position:relative;overflow:hidden;
}
.contact-aside::after{
  content:"";position:absolute;right:-90px;bottom:-90px;width:230px;height:230px;
  border-radius:50%;background:radial-gradient(circle,rgba(134,199,159,.42),transparent 70%);
}
.contact-aside h3{position:relative;font-family:var(--font-mincho);font-size:1.34rem;font-weight:800;line-height:1.6;letter-spacing:.03em;}
.contact-aside p{position:relative;margin-top:14px;font-size:.92rem;color:rgba(232,248,238,.8);}
.contact-aside .cinfo{position:relative;margin-top:26px;display:flex;flex-direction:column;gap:14px;}
.contact-aside .cinfo div{display:flex;gap:12px;align-items:flex-start;font-size:.9rem;}
.contact-aside .cinfo svg{flex-shrink:0;width:19px;height:19px;stroke:var(--green-bright);margin-top:3px;}

.form-card{
  background:#fff;border:1px solid var(--line);border-radius:24px;
  padding:38px 36px;box-shadow:var(--shadow-sm);
}
.wp-note{
  display:flex;gap:10px;align-items:flex-start;
  background:var(--bg-mint);border:1px dashed rgba(95,174,127,.45);
  border-radius:11px;padding:13px 16px;margin-bottom:26px;
  font-size:.8rem;color:var(--green-ink);line-height:1.7;
}
.wp-note svg{flex-shrink:0;width:18px;height:18px;stroke:var(--green);margin-top:2px;}
.field{margin-bottom:20px;}
.field label{
  display:block;font-size:.9rem;font-weight:700;margin-bottom:8px;
}
.field label .req{
  font-size:.68rem;color:#fff;background:var(--green);
  padding:2px 7px;border-radius:5px;margin-left:7px;vertical-align:2px;
}
.field input,.field select,.field textarea{
  width:100%;font-family:inherit;font-size:.96rem;color:var(--ink);
  background:var(--bg-soft);border:1.5px solid var(--line);
  border-radius:11px;padding:13px 15px;transition:border-color .2s ease,background .2s ease;
}
.field textarea{resize:vertical;min-height:130px;line-height:1.8;}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--green);background:#fff;
}
.form-submit{
  width:100%;justify-content:center;margin-top:6px;
  font-size:1.02rem;padding:16px;
}

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{
  background:linear-gradient(160deg,var(--green-deep),var(--green-deeper));
  color:rgba(232,248,238,.72);padding:64px 0 30px;
}
.footer-top{
  display:grid;grid-template-columns:1.4fr 1fr;gap:40px;
  padding-bottom:38px;border-bottom:1px solid rgba(255,255,255,.12);
}
.footer-brand .brand__mark{font-size:1.5rem;color:#fff;}
.footer-brand .brand__name{color:rgba(232,248,238,.66);}
.footer-brand p{margin-top:14px;font-size:.86rem;max-width:330px;}
.footer-nav{
  display:flex;flex-wrap:wrap;gap:10px 26px;align-content:start;
}
.footer-nav a{font-size:.9rem;font-weight:500;transition:color .2s ease;}
.footer-nav a:hover{color:var(--green-bright);}
.footer-bottom{
  padding-top:24px;display:flex;justify-content:space-between;
  align-items:center;gap:16px;flex-wrap:wrap;
  font-size:.8rem;
}
.footer-bottom .copy{font-family:var(--font-lat);letter-spacing:.04em;}

/* =========================================================
   MOBILE FIXED CTA
   ========================================================= */
.mobile-cta{
  display:none;position:fixed;left:0;right:0;bottom:0;z-index:90;
  padding:10px 16px calc(10px + env(safe-area-inset-bottom));
  background:rgba(255,255,255,.96);backdrop-filter:blur(10px);
  border-top:1px solid var(--line);
}
.mobile-cta a{
  display:flex;align-items:center;justify-content:center;gap:8px;
  background:linear-gradient(135deg,var(--green),var(--green-hover));
  color:#fff;font-weight:700;font-size:1rem;
  padding:15px;border-radius:13px;
  box-shadow:0 8px 20px rgba(95,174,127,.34);
}
.mobile-cta a svg{width:18px;height:18px;}

/* =========================================================
   REVEAL ANIMATION
   ========================================================= */
[data-reveal]{
  opacity:0;transform:translateY(26px);
  transition:opacity .7s ease,transform .7s ease;
}
[data-reveal].is-visible{opacity:1;transform:none;}
[data-reveal][data-delay="1"]{transition-delay:.08s;}
[data-reveal][data-delay="2"]{transition-delay:.16s;}
[data-reveal][data-delay="3"]{transition-delay:.24s;}
[data-reveal][data-delay="4"]{transition-delay:.32s;}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  [data-reveal]{opacity:1;transform:none;transition:none;}
  .video-ph__btn{animation:none;}
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1040px){
  .biz-grid,.prod-grid{grid-template-columns:1fr 1fr;}
  .cap-grid{grid-template-columns:1fr 1fr;}
  .flow{grid-template-columns:repeat(3,1fr);}
  .flow-step:nth-child(3)::after{display:none;}
  .lineup-grid{grid-template-columns:1fr 1fr;}
}
@media (max-width:900px){
  .nav{display:none;}
  .burger{display:block;}
  .hero-grid{grid-template-columns:1fr;gap:40px;}
  .hero-copy{order:2;}
  .hero-media{order:1;}
  .split{grid-template-columns:1fr;gap:28px;padding:30px;}
  .split--rev .split__media,.split--rev .split__text{order:initial;}
  .contact-wrap{grid-template-columns:1fr;gap:24px;}
  .footer-top{grid-template-columns:1fr;gap:28px;}
  .mobile-cta{display:block;}
  body{padding-bottom:78px;}
}
@media (max-width:620px){
  .section{padding:74px 0;}
  .container{padding:0 20px;}
  .biz-grid,.prod-grid,.cap-grid,.lineup-grid{grid-template-columns:1fr;}
  .flow{grid-template-columns:1fr 1fr;}
  .flow-step::after{display:none;}
  .hero-strip{grid-template-columns:1fr;}
  .hero-strip div{padding:18px 4px 4px;border-bottom:1px solid rgba(255,255,255,.1);}
  .company-row{grid-template-columns:1fr;}
  .company-row dt{padding-bottom:6px;}
  .company-row dd{padding-top:6px;}
  .hero-actions .btn{flex:1;justify-content:center;}
  .form-card,.contact-aside{padding:28px 22px;}
  .s-head{margin-bottom:38px;}
}
