/* ── ふたば flower shop — shared landing page styles (theme-driven via CSS vars) ── */

.fsite {
  --bg:#faf7f1; --surface:#ffffff; --surface2:#f3efe6;
  --ink:#39362f; --muted:#7c776c; --line:#e6e0d4;
  --brand:#8aa17f; --brand-deep:#56684f; --on-brand:#f7f4ec;
  --accent:#c47b5a; --accent2:#d6a89b;
  --font-display:"Zen Maru Gothic", sans-serif;
  --font-body:"Zen Kaku Gothic New", sans-serif;
  --mono:"DM Mono", ui-monospace, monospace;
  --radius:18px; --maxw:980px;

  width:1180px; background:var(--bg); color:var(--ink);
  font-family:var(--font-body); font-size:16px; line-height:1.85;
  letter-spacing:.01em; -webkit-font-smoothing:antialiased;
  font-feature-settings:"palt" 1;
}
.fsite *{ box-sizing:border-box; margin:0; padding:0; }
.fsite h1,.fsite h2,.fsite h3{ font-family:var(--font-display); font-weight:700; line-height:1.35; letter-spacing:.02em; }

.fsite .wrap{ max-width:var(--maxw); margin:0 auto; padding:0 64px; }
.fsite .eyebrow{ font-family:var(--mono); font-size:11.5px; letter-spacing:.28em; text-transform:uppercase; color:var(--accent); display:block; margin-bottom:18px; }
.fsite .lead{ color:var(--muted); }

/* placeholder image */
.fsite .ph{
  position:relative; border-radius:var(--radius); overflow:hidden;
  background:
    repeating-linear-gradient(135deg, color-mix(in oklab,var(--brand) 16%,transparent) 0 10px, transparent 10px 20px),
    color-mix(in oklab,var(--brand) 9%, var(--surface));
  border:1px solid color-mix(in oklab,var(--brand) 22%,transparent);
  display:flex; align-items:flex-end; min-height:120px;
}
.fsite .ph span{
  font-family:var(--mono); font-size:11px; letter-spacing:.06em; color:color-mix(in oklab,var(--ink) 60%,transparent);
  background:color-mix(in oklab,var(--surface) 86%,transparent); backdrop-filter:blur(2px);
  padding:5px 10px; border-radius:7px; margin:12px; position:relative; z-index:1;
}
.fsite .ph span i{ font-style:normal; opacity:.6; }
.fsite .ph .ph-img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; }

/* nav */
.fsite .nav{ display:flex; align-items:center; justify-content:space-between; padding:26px 64px; max-width:1100px; margin:0 auto; }
.fsite .brand{ display:flex; align-items:baseline; gap:10px; }
.fsite .brand .mark{ font-family:var(--font-display); font-size:25px; font-weight:700; color:var(--brand-deep); letter-spacing:.06em; }
.fsite .brand .mark em{ font-style:normal; color:var(--accent); }
.fsite .brand .romaji{ font-family:var(--mono); font-size:10.5px; letter-spacing:.32em; text-transform:uppercase; color:var(--muted); }
.fsite .navlinks{ display:flex; gap:30px; align-items:center; }
.fsite .navlinks a{ font-size:13.5px; color:var(--ink); text-decoration:none; opacity:.82; }
.fsite .navlinks a:hover{ opacity:1; color:var(--brand-deep); }
.fsite .btn{ display:inline-flex; align-items:center; gap:8px; font-family:var(--font-body); font-size:14px; font-weight:500;
  padding:11px 22px; border-radius:999px; border:1px solid var(--brand-deep); background:var(--brand-deep); color:var(--on-brand);
  text-decoration:none; cursor:pointer; transition:transform .15s ease, opacity .15s ease; }
.fsite .btn:hover{ opacity:.9; transform:translateY(-1px); }
.fsite .btn.ghost{ background:transparent; color:var(--brand-deep); }
.fsite .btn.lg{ padding:14px 28px; font-size:15px; }

/* hero */
.fsite .hero{ display:grid; grid-template-columns:1fr 1fr; gap:54px; align-items:center; padding:46px 64px 86px; max-width:1100px; margin:0 auto; }
.fsite .hero h1{ font-size:52px; line-height:1.28; margin:14px 0 22px; }
.fsite .hero .lead{ font-size:17px; max-width:30ch; }
.fsite .hero .cta{ display:flex; gap:14px; margin-top:32px; flex-wrap:wrap; }
.fsite .hero .ph{ min-height:430px; }

/* generic section */
.fsite section{ padding:84px 0; }
.fsite .sec-head{ max-width:62ch; margin-bottom:46px; }
.fsite .sec-head h2{ font-size:34px; margin:0 0 16px; }
.fsite .sec-head .lead{ font-size:16.5px; }

/* plant cards */
.fsite .cards{ display:grid; grid-template-columns:repeat(2,1fr); gap:26px; }
.fsite .card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
.fsite .card .ph{ border-radius:0; border:0; border-bottom:1px solid var(--line); min-height:176px; }
.fsite .card .body{ padding:24px 26px 28px; }
.fsite .card h3{ font-size:20px; margin-bottom:9px; display:flex; align-items:baseline; gap:10px; }
.fsite .card h3 .jp{ font-family:var(--mono); font-size:10.5px; letter-spacing:.2em; color:var(--brand); text-transform:uppercase; }
.fsite .card p{ font-size:14.5px; color:var(--muted); }

/* delivery */
.fsite .sec-delivery .inner{ display:grid; grid-template-columns:1fr 1fr; gap:54px; align-items:center; }
.fsite .seasons{ display:grid; grid-template-columns:repeat(2,1fr); gap:16px; margin-top:30px; }
.fsite .season{ border:1px solid var(--line); border-radius:14px; padding:18px 20px; background:var(--surface); }
.fsite .season b{ font-family:var(--font-display); font-size:17px; color:var(--brand-deep); display:block; }
.fsite .season b em{ font-style:normal; font-family:var(--mono); font-size:10px; letter-spacing:.22em; color:var(--accent); margin-left:8px; text-transform:uppercase; }
.fsite .season p{ font-size:13px; color:var(--muted); margin-top:5px; }
.fsite .sec-delivery .ph{ min-height:400px; }
.fsite .note{ font-size:13px; color:var(--muted); margin-top:22px; font-family:var(--mono); letter-spacing:.02em; }

/* care */
.fsite .sec-care{ background:var(--surface2); }
.fsite .tips{ display:grid; grid-template-columns:repeat(3,1fr); gap:30px; margin-top:8px; }
.fsite .tip{ padding-top:24px; border-top:2px solid var(--brand); }
.fsite .tip .n{ font-family:var(--mono); font-size:12px; letter-spacing:.2em; color:var(--accent); }
.fsite .tip h3{ font-size:21px; margin:12px 0 10px; }
.fsite .tip p{ font-size:14.5px; color:var(--muted); }

/* store info */
.fsite .sec-store .inner{ display:grid; grid-template-columns:0.9fr 1.1fr; gap:48px; align-items:stretch; }
.fsite .info dl{ display:grid; grid-template-columns:auto 1fr; gap:14px 24px; margin-top:6px; }
.fsite .info dt{ font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--brand); padding-top:4px; }
.fsite .info dd{ font-size:15.5px; }
.fsite .sec-store .map{ min-height:300px; border-radius:var(--radius); }

/* footer */
.fsite footer{ background:var(--brand-deep); color:var(--on-brand); padding:60px 64px 40px; }
.fsite footer .inner{ max-width:var(--maxw); margin:0 auto; display:flex; justify-content:space-between; align-items:flex-start; gap:40px; flex-wrap:wrap; }
.fsite footer .mark{ font-family:var(--font-display); font-size:26px; font-weight:700; letter-spacing:.06em; }
.fsite footer .tag{ opacity:.8; font-size:14px; margin-top:10px; max-width:34ch; }
.fsite footer .social{ display:flex; gap:14px; margin-top:18px; }
.fsite footer .social a{ color:var(--on-brand); opacity:.85; text-decoration:none; font-size:13.5px; font-family:var(--mono); letter-spacing:.08em; border:1px solid color-mix(in oklab,var(--on-brand) 35%,transparent); padding:8px 16px; border-radius:999px; }
.fsite footer .social a:hover{ opacity:1; }
.fsite footer .copy{ opacity:.6; font-size:12px; font-family:var(--mono); margin-top:44px; letter-spacing:.06em; }

/* ───────────────────────── THEME B · editorial mincho ───────────────────────── */
.fsite[data-layout="b"]{ --radius:3px; --maxw:1000px; }
.fsite[data-layout="b"] .hero{ grid-template-columns:1fr; text-align:center; padding-bottom:64px; }
.fsite[data-layout="b"] .hero h1{ font-size:62px; letter-spacing:.04em; line-height:1.32; }
.fsite[data-layout="b"] .hero .lead{ max-width:46ch; margin:0 auto; }
.fsite[data-layout="b"] .hero .cta{ justify-content:center; }
.fsite[data-layout="b"] .hero .ph{ grid-row:2; min-height:360px; margin-top:40px; }
.fsite[data-layout="b"] .btn{ border-radius:0; }
.fsite[data-layout="b"] .card,.fsite[data-layout="b"] .season{ border-radius:0; }
.fsite[data-layout="b"] .sec-head{ margin-left:auto; margin-right:auto; text-align:center; }
.fsite[data-layout="b"] .eyebrow{ color:var(--muted); }

/* ───────────────────────── THEME C · lush color-block ───────────────────────── */
.fsite[data-layout="c"]{ --radius:22px; --maxw:1000px; }
.fsite[data-layout="c"] .btn{ border-color:var(--accent); background:var(--accent); }
.fsite[data-layout="c"] .btn.ghost{ background:transparent; color:var(--accent); }
.fsite[data-layout="c"] .sec-delivery{ background:var(--brand-deep); color:var(--on-brand); }
.fsite[data-layout="c"] .sec-delivery .eyebrow{ color:var(--accent2); }
.fsite[data-layout="c"] .sec-delivery .lead{ color:color-mix(in oklab,var(--on-brand) 78%,transparent); }
.fsite[data-layout="c"] .sec-delivery .season{ background:color-mix(in oklab,var(--on-brand) 10%,transparent); border-color:color-mix(in oklab,var(--on-brand) 22%,transparent); }
.fsite[data-layout="c"] .sec-delivery .season b{ color:var(--on-brand); }
.fsite[data-layout="c"] .sec-delivery .season p{ color:color-mix(in oklab,var(--on-brand) 70%,transparent); }
.fsite[data-layout="c"] .sec-delivery .note{ color:color-mix(in oklab,var(--on-brand) 65%,transparent); }
.fsite[data-layout="c"] .sec-care{ background:color-mix(in oklab,var(--accent2) 16%, var(--bg)); }
.fsite[data-layout="c"] .tip{ border-color:var(--accent); }

/* ───────────────────────── THEME D · clean grid ───────────────────────── */
.fsite[data-layout="d"]{ --radius:10px; --maxw:1040px; }
.fsite[data-layout="d"] .hero h1{ font-size:48px; letter-spacing:0; line-height:1.3; }
.fsite[data-layout="d"] .btn{ border-radius:6px; }
.fsite[data-layout="d"] .cards{ grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
.fsite[data-layout="d"] .card{ border:0; border-radius:0; }
.fsite[data-layout="d"] .card .ph{ min-height:150px; }
.fsite[data-layout="d"] .card .body{ padding:20px; }
.fsite[data-layout="d"] .card h3{ font-size:17px; flex-direction:column; gap:4px; }
.fsite[data-layout="d"] .season{ border-radius:8px; }
.fsite[data-layout="d"] h1,.fsite[data-layout="d"] h2,.fsite[data-layout="d"] h3{ letter-spacing:0; }

/* ───────────────────────── name candidate card ───────────────────────── */
.namecard{
  width:100%; background:var(--surface); color:var(--ink);
  border:1px solid var(--line); border-radius:var(--radius);
  padding:38px 36px 34px; font-family:var(--font-body);
  display:flex; flex-direction:column;
}
.namecard .nc-eyebrow{ font-family:var(--mono); font-size:10.5px; letter-spacing:.28em; text-transform:uppercase; color:var(--accent); }
.namecard .nc-mark{ font-family:var(--font-display); font-size:54px; font-weight:700; color:var(--brand-deep); letter-spacing:.08em; margin:22px 0 8px; line-height:1.1; }
.namecard .nc-mark em{ font-style:normal; color:var(--accent); }
.namecard .nc-romaji{ font-family:var(--mono); font-size:12px; letter-spacing:.32em; text-transform:uppercase; color:var(--muted); }
.namecard .nc-meaning{ font-size:14px; color:var(--muted); margin-top:18px; line-height:1.85; min-height:3.7em; }
.namecard hr{ border:0; border-top:1px solid var(--line); margin:20px 0 0; }
