@charset "UTF-8";
/* ============================================================
   サダミツ園芸 — Shared design system
   Token layer + shared components (header / footer / buttons /
   cards / badges / section headings). Page-specific layout lives
   in each page's own <style> block.
   Maps cleanly to a WordPress theme:
     :root tokens      -> theme.json / variables
     .site-header      -> header.php
     .site-footer      -> footer.php
     .btn / .card etc. -> reusable blocks / template parts
   ============================================================ */

/* ---- Fonts ---- */
@import url('https://fonts.googleapis.com/css2?family=Zen+Maru+Gothic:wght@400;500;700;900&family=Zen+Kaku+Gothic+New:wght@400;500;700&family=EB+Garamond:wght@400;500&display=swap');

/* ============================================================
   1. TOKENS
   ============================================================ */
:root{
  /* brand colour */
  --rose:        #e76674;   /* primary buttons */
  --rose-hover:  #df5566;
  --rose-ink:    #e2566b;   /* accent heading / link text */
  --rose-50:     #fff5f7;
  --rose-100:    #fce8ec;   /* soft card / band bg */
  --rose-150:    #fbdde3;
  --rose-200:    #f6c7d0;
  --rose-border: #f3cdd5;

  --cream:       #fdf6eb;   /* crop / warm sections */
  --cream-deep:  #f6ead2;

  --green:       #72994d;   /* secondary green button + accents */
  --green-hover: #648844;
  --green-ink:   #6a9a4b;
  --green-soft:  #8fb06a;

  --brown:       #9a7a4e;   /* rice season badge */

  --ink:         #4a423f;   /* body text */
  --ink-2:       #756b66;   /* muted text */
  --ink-3:       #9a908a;   /* faint notes */
  --line:        rgba(74,66,63,.10);

  --page-bg:     #fffcf8;

  /* type */
  --f-head: "Zen Maru Gothic", "Zen Kaku Gothic New", sans-serif;
  --f-body: "Zen Kaku Gothic New", "Zen Maru Gothic", sans-serif;
  --f-latin:"EB Garamond", "Zen Maru Gothic", serif;

  /* radius */
  --r-sm: 12px;
  --r-md: 18px;
  --r-lg: 26px;
  --r-xl: 34px;
  --r-pill: 999px;

  /* shadow */
  --sh-card: 0 10px 30px rgba(202,150,150,.16);
  --sh-soft: 0 6px 18px rgba(202,150,150,.12);
  --sh-btn:  0 8px 18px rgba(231,102,116,.30);

  /* layout */
  --container: 1180px;
  --gutter: 24px;
}

/* ============================================================
   2. BASE
   ============================================================ */
*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
body{
  margin:0;
  font-family:var(--f-body);
  color:var(--ink);
  background:var(--page-bg);
  line-height:1.85;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
h1,h2,h3,h4,p,ul,figure{margin:0;}
ul{list-style:none;padding:0;}
button{font-family:inherit;cursor:pointer;}

.container{max-width:var(--container);margin:0 auto;padding:0 var(--gutter);}

/* utility: replaceable photo wrapper keeps layout when image swapped */
.media{position:relative;overflow:hidden;background:#f3ece4;}
.media img{width:100%;height:100%;object-fit:cover;display:block;}

/* user-replaceable photo slot — fills its (shape-defining) parent.
   Click or drag-and-drop an image to swap; the change is saved. */
/* user-replaceable photo — plain <img>, always renders. Click to swap. */
.photo{display:block;width:100%;height:100%;object-fit:cover;}
img[data-editable]{cursor:pointer;transition:filter .15s;}
img[data-editable]:hover{filter:brightness(.93);outline:3px solid rgba(231,102,116,.75);outline-offset:-3px;}

/* decorative illustration (absolutely placed brand art) */
.decor{position:absolute;pointer-events:none;user-select:none;z-index:2;}
/* 差し替え可能にした装飾画像はクリックを受け付ける */
.decor[data-editable]{pointer-events:auto;}

/* ============================================================
   3. HEADER  (header.php)
   ============================================================ */
.site-header{
  position:sticky;top:0;z-index:50;
  background:#fffdfa;
  border-bottom:1px solid var(--line);
}
.site-header__inner{
  max-width:1320px;margin:0 auto;padding:14px 26px;
  display:flex;align-items:center;gap:20px;
}
.brand{display:flex;align-items:center;gap:11px;flex-shrink:0;}
.brand__mark{width:42px;height:42px;object-fit:contain;}
.brand__text{display:flex;flex-direction:column;line-height:1;}
.brand__name{font-family:var(--f-head);font-weight:700;font-size:25px;color:#3f3a37;letter-spacing:.04em;}
.brand__latin{font-family:var(--f-latin);font-size:11px;letter-spacing:.30em;color:var(--rose);margin-top:5px;white-space:nowrap;}

.main-nav{margin-left:auto;}
.main-nav ul{display:flex;align-items:center;gap:18px;}
.main-nav a{
  font-family:var(--f-head);font-weight:500;font-size:14.5px;color:#5a524e;
  padding:6px 2px;position:relative;white-space:nowrap;transition:color .2s;
}
.main-nav a:hover{color:var(--rose-ink);}
.main-nav a.is-active{color:var(--rose-ink);}
.main-nav a.is-active::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;
  background:var(--rose-ink);border-radius:2px;
}
.header-cta{flex-shrink:0;}
/* nav内CTAはモバイルのドロップダウン専用（PCではheader-ctaを使う） */
.nav-cta{display:none;}

/* hamburger (mobile nav toggle) */
.nav-toggle{display:none;flex-shrink:0;width:46px;height:46px;border:0;background:var(--rose-50);border-radius:12px;cursor:pointer;align-items:center;justify-content:center;padding:0;margin-left:6px;}
.nav-toggle span{position:relative;display:block;width:22px;height:2px;background:var(--rose-ink);border-radius:2px;transition:transform .25s, opacity .2s;}
.nav-toggle span::before,.nav-toggle span::after{content:"";position:absolute;left:0;width:22px;height:2px;background:var(--rose-ink);border-radius:2px;transition:transform .25s, opacity .2s;}
.nav-toggle span::before{top:-7px;}
.nav-toggle span::after{top:7px;}
.site-header.is-open .nav-toggle span{background:transparent;}
.site-header.is-open .nav-toggle span::before{transform:translateY(7px) rotate(45deg);}
.site-header.is-open .nav-toggle span::after{transform:translateY(-7px) rotate(-45deg);}

/* ============================================================
   4. BUTTONS  (reusable block)
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--f-head);font-weight:700;font-size:16px;line-height:1;
  padding:15px 28px;border-radius:var(--r-pill);border:2px solid transparent;
  transition:transform .15s, box-shadow .2s, background .2s, color .2s;
  cursor:pointer;text-align:center;white-space:nowrap;
}
.btn .ico{width:18px;height:18px;flex-shrink:0;}
.btn:hover{transform:translateY(-2px);}
.btn--rose{background:var(--rose);color:#fff;box-shadow:var(--sh-btn);}
.btn--rose:hover{background:var(--rose-hover);}
.btn--green{background:var(--green);color:#fff;box-shadow:0 8px 18px rgba(114,153,77,.30);}
.btn--green:hover{background:var(--green-hover);}
.btn--outline-rose{background:#fff;color:var(--rose-ink);border-color:var(--rose-200);}
.btn--outline-rose:hover{background:var(--rose-50);}
.btn--outline-green{background:#fff;color:var(--green-ink);border-color:#cfe0b8;}
.btn--outline-green:hover{background:#f4f8ee;}
.btn--ghost{background:#fff;color:var(--rose-ink);border-color:var(--rose-border);box-shadow:var(--sh-soft);}
.btn--sm{font-size:14px;padding:11px 20px;}
.btn--lg{font-size:18px;padding:18px 38px;}
.btn--block{display:flex;width:100%;}

/* ============================================================
   5. SECTION HEADING  (leaf-flanked centred title)
   ============================================================ */
.section-head{text-align:center;margin-bottom:42px;}
.section-head__title{
  display:inline-flex;align-items:center;gap:16px;justify-content:center;
  font-family:var(--f-head);font-weight:700;font-size:30px;color:var(--ink);
  letter-spacing:.04em;
}
.section-head__title::before,
.section-head__title::after{
  content:"";width:44px;height:36px;flex-shrink:0;
  background:url('../img/decor/leaf-sprig.png') center/contain no-repeat;
}
.section-head__title::after{transform:scaleX(-1);}
.section-head__sub{margin-top:14px;color:var(--ink-2);font-size:16px;}
.section-head--rose .section-head__title{color:var(--rose-ink);}

/* dotted divider used under page titles & headings */
.dot-rule{
  width:160px;height:8px;margin:18px auto 0;
  background-image:radial-gradient(circle, var(--rose-200) 42%, transparent 44%);
  background-size:16px 8px;background-repeat:repeat-x;background-position:center;
}

/* ============================================================
   6. SEASON BADGE
   ============================================================ */
.badge{
  display:inline-flex;align-items:center;justify-content:center;text-align:center;
  font-family:var(--f-head);font-weight:700;font-size:13px;line-height:1.25;
  color:#fff;padding:7px 13px;border-radius:var(--r-pill);
}
.badge--rose{background:var(--rose);}
.badge--brown{background:var(--brown);}
.badge--green{background:var(--green-soft);}
.badge--season-text{
  background:#fff;color:var(--rose-ink);border:1.5px solid var(--rose-200);
  border-radius:8px;padding:5px 12px;font-size:13px;
}

/* ============================================================
   7. CARDS
   ============================================================ */
.card{background:#fff;border-radius:var(--r-lg);box-shadow:var(--sh-card);}

/* store / sales-location card */
.store-card{background:#fff;border-radius:var(--r-lg);box-shadow:var(--sh-card);overflow:hidden;}
.store-card__media{aspect-ratio:16/9;}
.store-card__body{padding:24px 26px 26px;}
.store-card__name{font-family:var(--f-head);font-weight:700;font-size:23px;margin-bottom:14px;}
.store-card__name--rose{color:var(--rose-ink);}
.store-card__name--green{color:var(--green-ink);}
.info-line{display:flex;align-items:flex-start;gap:11px;color:var(--ink);font-size:16px;line-height:1.7;margin:8px 0;}
.info-line .ico{width:19px;height:19px;margin-top:4px;flex-shrink:0;color:var(--rose);}
.info-line--green .ico{color:var(--green);}

/* generic icon */
.ico{display:inline-block;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
.ico--fill{fill:currentColor;stroke:none;}

/* ============================================================
   8. PAGE HERO  (sub-page header band with pink wave)
   ============================================================ */
.page-hero{position:relative;background:linear-gradient(180deg,#fdeef0 0%,#fde6ea 100%);overflow:hidden;}
.page-hero__wave{position:absolute;left:0;right:0;bottom:-1px;width:100%;display:block;}
.breadcrumb{font-size:13px;color:var(--ink-2);padding:16px 0 0;position:relative;z-index:3;}
.breadcrumb a:hover{color:var(--rose-ink);}
.breadcrumb span{margin:0 8px;color:var(--ink-3);}

/* centred page title (faq / contact style) */
.page-title{font-family:var(--f-head);font-weight:700;font-size:48px;color:var(--ink);text-align:center;letter-spacing:.06em;}
.page-title--lead{margin-bottom:4px;}

/* ============================================================
   9. FOOTER  (footer.php)
   ============================================================ */
.site-footer{position:relative;background:#fffaf6;padding-top:60px;}
.site-footer__grass-wrap{position:relative;margin-top:8px;}
.site-footer__grass{display:block;width:100%;height:auto;}
.footer-main{padding:0 0 30px;}
.footer-grid{display:grid;grid-template-columns:1.1fr 1.4fr;gap:40px;align-items:start;}
.footer-brand .brand__name{font-size:24px;}
.footer-contact{margin-top:16px;font-size:14.5px;color:var(--ink);line-height:2;}
.footer-contact .info-line{font-size:14.5px;margin:4px 0;}
.footer-sitemap{display:grid;grid-template-columns:repeat(3,1fr);gap:8px 26px;}
.footer-sitemap a{display:flex;align-items:center;gap:8px;font-size:14.5px;color:var(--ink);padding:5px 0;}
.footer-sitemap a::before{content:"";width:16px;height:13px;background:url('../img/decor/leaf-sprig.png') center/contain no-repeat;flex-shrink:0;}
.footer-sitemap a:hover{color:var(--rose-ink);}
.footer-copy{position:absolute;left:0;right:0;bottom:6%;text-align:center;font-family:var(--f-head);font-weight:700;font-size:13px;letter-spacing:.06em;color:#5a7a4a;text-shadow:0 1px 2px rgba(255,255,255,.7);}
@media(max-width:720px){.footer-copy{font-size:11px;bottom:4%;}}

/* social round button */
.social-ig{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:12px;background:linear-gradient(45deg,#f9a03f,#e1306c 40%,#c13584 70%,#833ab4);color:#fff;}
.social-ig .ico{width:22px;height:22px;}

/* ============================================================
   10. SHARED CTA BAND  (pink rounded prompt with strawberries)
   ============================================================ */
.cta-band{
  position:relative;background:var(--rose-100);border-radius:var(--r-xl);
  padding:34px 56px;display:flex;align-items:center;justify-content:center;gap:34px;
  flex-wrap:wrap;overflow:hidden;
}
.cta-band__text{font-family:var(--f-head);font-weight:700;font-size:19px;color:var(--ink);line-height:1.7;text-align:center;}
.cta-band__buttons{display:flex;gap:18px;flex-wrap:wrap;}

/* notes */
.note{font-size:13px;color:var(--ink-3);line-height:1.8;}

/* section vertical rhythm */
.section{padding:84px 0;}
.section--cream{background:var(--cream);}
.section--rose{background:var(--rose-50);}

/* ============================================================
   10b. UNIFIED CONTACT SECTION  (お問い合わせ先 — shared on all pages)
   ============================================================ */
.contact-info{position:relative;background:#fff;border:1.5px solid var(--rose-100);border-radius:var(--r-xl);
  padding:46px 60px;box-shadow:var(--sh-soft);overflow:hidden;}
.contact-info .decor-flowers-l{left:1.5%;bottom:14px;width:150px;}
.contact-info .decor-cluster-r{right:1.5%;bottom:10px;width:170px;}
.contact-info__sub{text-align:center;color:var(--ink-2);margin-top:6px;}
.contact-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:30px;position:relative;z-index:3;}
.contact-col{text-align:center;padding:6px 18px;position:relative;}
.contact-col + .contact-col::before{content:"";position:absolute;left:0;top:14%;height:72%;width:1px;
  background-image:linear-gradient(var(--rose-150) 50%,transparent 50%);background-size:1px 8px;}
.contact-col__label{font-size:13.5px;color:var(--ink-2);}
.contact-col__icon{width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 12px;}
.contact-col__icon .ico{width:26px;height:26px;}
.ic-rose{background:var(--rose);color:#fff;}
.ic-ig{background:linear-gradient(45deg,#f9a03f,#e1306c 45%,#c13584 70%,#833ab4);color:#fff;}
.ic-green{background:#eef4e6;color:var(--green);}
.contact-col__main{font-family:var(--f-head);font-weight:700;font-size:21px;color:var(--ink);margin:6px 0 4px;}
.contact-col__main.is-phone{color:var(--rose-ink);}
.contact-col__note{font-size:12.5px;color:var(--ink-3);}
a.contact-col{color:inherit;transition:transform .15s;}
a.contact-col:hover{transform:translateY(-2px);}
a.contact-col:hover .contact-col__main{color:var(--rose-ink);}
@media (max-width:720px){
  .contact-info{padding:32px 22px;}
  .contact-cols{grid-template-columns:1fr;gap:24px;}
  .contact-col + .contact-col::before{display:none;}
  .contact-col + .contact-col{border-top:1px dashed var(--rose-150);padding-top:22px;}
}

/* ============================================================
   12. CONTENT HERO  (left text / right photo sub-page lead)
   ============================================================ */
.lead-hero{position:relative;overflow:hidden;background:linear-gradient(180deg,#fdeef0 0%,#fde7ec 100%);}
.lead-hero__bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.08;z-index:0;cursor:pointer;transition:opacity .15s;}
.lead-hero__bg[data-editable]:hover{opacity:.16;outline:3px solid rgba(231,102,116,.6);outline-offset:-3px;}
.lead-hero__grid{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center;padding:10px 0 70px;position:relative;z-index:3;}
.lead-hero__title{font-family:var(--f-head);font-weight:700;font-size:46px;color:var(--ink);letter-spacing:.03em;line-height:1.3;}
.lead-hero__accent{font-family:var(--f-head);font-weight:700;font-size:26px;color:var(--rose-ink);line-height:1.55;margin-top:22px;}
.lead-hero__text{margin-top:18px;color:var(--ink-2);font-size:16px;line-height:2;}
.lead-hero__copy{position:relative;}
.lead-hero__media{position:relative;aspect-ratio:4/3;border-radius:30px 30px 30px 120px;overflow:hidden;box-shadow:var(--sh-card);}
.lead-hero__media img{width:100%;height:100%;object-fit:cover;}
.lead-hero .decor-blossom{width:120px;}
.alert-pill{display:inline-flex;align-items:center;gap:10px;margin-top:26px;background:#fff;border:1.5px solid var(--rose-150);
  border-radius:var(--r-pill);padding:11px 22px;color:var(--rose-ink);font-family:var(--f-head);font-weight:700;font-size:15px;box-shadow:var(--sh-soft);}
.alert-pill .ico{width:20px;height:20px;color:var(--rose);}

/* ============================================================
   13. CROP CARDS  (seasonal produce)
   ============================================================ */
.crop-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
.crop-card{position:relative;background:#fff;border-radius:var(--r-md);box-shadow:var(--sh-card);overflow:hidden;}
.crop-card__media{aspect-ratio:4/3;}
.crop-card__badge{position:absolute;top:12px;left:12px;z-index:3;white-space:pre-line;line-height:1.2;}
.crop-card__body{padding:16px 20px 22px;}
.crop-card__name{display:flex;align-items:center;gap:8px;font-family:var(--f-head);font-weight:700;font-size:20px;margin-bottom:8px;}
.crop-card__name .em{font-size:20px;line-height:1;}
.crop-card__desc{font-size:14px;line-height:1.85;color:var(--ink);}
.name-rose{color:var(--rose-ink);}
.name-brown{color:var(--brown);}
.name-green{color:var(--green-ink);}

/* ============================================================
   14. PRODUCER BAND  (about page)
   ============================================================ */
.producer{position:relative;background:var(--rose-100);border-radius:var(--r-xl);padding:40px 56px;overflow:hidden;display:grid;grid-template-columns:auto 1fr auto;gap:34px;align-items:center;}
.producer__photo{width:150px;height:150px;border-radius:24px;overflow:hidden;flex-shrink:0;box-shadow:var(--sh-soft);}
.producer__photo img{width:100%;height:100%;object-fit:cover;}
.producer__title{display:flex;align-items:center;gap:10px;font-family:var(--f-head);font-weight:700;font-size:23px;color:var(--ink);margin-bottom:12px;}
.producer__title img{width:28px;height:28px;}
.producer__text{font-size:15.5px;line-height:1.95;color:var(--ink);}
.producer__note{position:relative;font-family:var(--f-head);font-weight:700;color:var(--rose-ink);font-size:18px;transform:rotate(-7deg);text-align:center;white-space:nowrap;}
.producer .decor-straw-cut{position:static;width:120px;margin-top:10px;}

/* split section (photo + copy) */
.split{display:grid;grid-template-columns:1fr 1.1fr;gap:50px;align-items:center;}
.split__media{aspect-ratio:4/3;border-radius:46% 54% 50% 50%/52% 50% 50% 48%;overflow:hidden;box-shadow:var(--sh-card);}
.split__media img{width:100%;height:100%;object-fit:cover;}
.heading-leaf{display:flex;align-items:center;gap:12px;font-family:var(--f-head);font-weight:700;font-size:28px;color:var(--ink);}
.heading-leaf img{width:34px;height:34px;}
.lead-p{color:var(--ink);font-size:16px;line-height:2;margin-top:8px;}
.lead-p + .lead-p{margin-top:18px;}

/* ============================================================
   11. RESPONSIVE
   ============================================================ */
@media (max-width:920px){
  .lead-hero__grid,.split,.producer{grid-template-columns:1fr;}
  .crop-grid{grid-template-columns:repeat(2,1fr);}
  .producer__note{transform:none;}
}
@media (max-width:1180px){
  .footer-grid{grid-template-columns:1fr;}
  .nav-toggle{display:flex;}
  .header-cta{display:none;}
  .main-nav{position:absolute;left:0;right:0;top:100%;margin:0;background:#fffdfa;border-bottom:1px solid var(--line);box-shadow:0 16px 30px rgba(150,90,90,.14);
    display:none;}
  .site-header.is-open .main-nav{display:block;}
  .main-nav ul{flex-direction:column;align-items:stretch;gap:0;padding:8px 0 14px;}
  .main-nav li{border-top:1px solid var(--rose-100);}
  .main-nav li:first-child{border-top:0;}
  .main-nav a{display:block;padding:15px 30px;font-size:16px;}
  .main-nav a.is-active::after{display:none;}
  .main-nav a.is-active{background:var(--rose-50);}
  .main-nav .nav-cta{margin:12px 30px 0;display:block;}
  .main-nav .nav-cta a{display:inline-flex;padding:13px 24px;color:#fff;}
}
@media (max-width:720px){
  .page-title{font-size:34px;}
  .lead-hero__title{font-size:33px;}
  .lead-hero__accent{font-size:20px;}
  .lead-hero__text{font-size:15px;}
  .section{padding:56px 0;}
  .section-head__title{font-size:24px;}
  .cta-band{padding:28px 24px;}
  .footer-sitemap{grid-template-columns:repeat(2,1fr);}
}
