/* Emerald Coast Flower Delivery — premium storefront styles
   Soft floral palette · mobile-first · vanilla, no frameworks. */

:root{
  --ink:#2b2620;          /* warm near-black text */
  --ink-soft:#6f675d;     /* muted body */
  --cream:#fbf7f2;        /* page background */
  --card:#ffffff;
  --line:#ece4da;         /* hairline */
  --blush:#e9b9c4;        /* soft rose */
  --rose:#c25b73;         /* primary rose */
  --rose-deep:#a8475f;
  --sage:#5f7a63;         /* emerald-coast green */
  --sage-deep:#4a6350;
  --gold:#c8a24a;         /* accent */
  --shadow:0 18px 50px -22px rgba(60,40,30,.35);
  --shadow-sm:0 6px 20px -10px rgba(60,40,30,.3);
  --radius:18px;
  --maxw:1180px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Jost',system-ui,-apple-system,sans-serif;
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,.serif{font-family:'Cormorant Garamond',Georgia,serif;font-weight:600;line-height:1.12;letter-spacing:.2px}
a{color:inherit}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.center{text-align:center}
.muted{color:var(--ink-soft)}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:'Jost',sans-serif;font-weight:600;font-size:1.02rem;letter-spacing:.3px;
  padding:15px 30px;border-radius:999px;border:1.5px solid transparent;
  cursor:pointer;text-decoration:none;transition:transform .15s ease,box-shadow .2s ease,background .2s ease;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--rose);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--rose-deep)}
.btn-call{background:var(--sage);color:#fff;box-shadow:var(--shadow-sm)}
.btn-call:hover{background:var(--sage-deep)}
.btn-ghost{background:transparent;border-color:var(--rose);color:var(--rose-deep)}
.btn-ghost:hover{background:rgba(194,91,115,.08)}
.btn-block{width:100%}

/* ---------- top announcement + nav ---------- */
.announce{
  background:var(--sage-deep);color:#fff;text-align:center;
  font-size:.86rem;letter-spacing:.5px;padding:9px 14px;
}
.announce strong{color:#f6e7c8}
.nav{
  position:sticky;top:0;z-index:50;background:rgba(251,247,242,.92);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line);
}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;min-height:68px;gap:14px}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none}
.brand .mark{width:34px;height:34px;flex:0 0 34px}
.brand b{font-family:'Cormorant Garamond',serif;font-size:1.45rem;font-weight:600;letter-spacing:.3px}
.nav-links{display:none;gap:26px;align-items:center}
.nav-links a{text-decoration:none;font-size:.95rem;color:var(--ink-soft);transition:color .15s}
.nav-links a:hover{color:var(--rose-deep)}
.nav-cta{display:flex;align-items:center;gap:10px}
.nav-phone{display:none;text-decoration:none;font-weight:600;color:var(--sage-deep);font-size:.98rem}
@media(min-width:860px){.nav-links{display:flex}.nav-phone{display:inline}}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;
  background:
    radial-gradient(120% 90% at 12% 0%,rgba(233,185,196,.55),transparent 55%),
    radial-gradient(120% 100% at 100% 20%,rgba(95,122,99,.28),transparent 55%),
    linear-gradient(180deg,#fdf4ef 0%,var(--cream) 100%);
}
.hero .wrap{padding:64px 22px 72px;display:grid;gap:40px;align-items:center}
.hero-copy .eyebrow{
  display:inline-block;font-size:.78rem;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--sage-deep);font-weight:600;margin-bottom:18px;
}
.hero h1{font-size:clamp(2.5rem,7vw,4.2rem);margin-bottom:18px}
.hero h1 em{font-style:italic;color:var(--rose-deep)}
.hero-sub{font-size:clamp(1.05rem,2.4vw,1.3rem);color:var(--ink-soft);max-width:560px;margin-bottom:28px}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:22px}
.hero-note{font-size:.9rem;color:var(--ink-soft)}
.hero-note b{color:var(--ink)}
.hero-art{position:relative;min-height:300px;border-radius:24px;overflow:hidden;box-shadow:var(--shadow)}
@media(min-width:900px){.hero .wrap{grid-template-columns:1.05fr .95fr;padding:84px 22px 92px}}

/* ---------- trust bar ---------- */
.trust{background:var(--card);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.trust .wrap{display:grid;grid-template-columns:1fr;gap:18px;padding:26px 22px}
.trust-item{display:flex;gap:12px;align-items:flex-start}
.trust-item .ic{flex:0 0 30px;width:30px;height:30px;color:var(--rose)}
.trust-item h4{font-family:'Jost',sans-serif;font-weight:600;font-size:.98rem;margin-bottom:2px}
.trust-item p{font-size:.86rem;color:var(--ink-soft);line-height:1.45}
@media(min-width:760px){.trust .wrap{grid-template-columns:repeat(4,1fr);gap:26px}}

/* ---------- section frame ---------- */
.section{padding:72px 0}
.section-head{text-align:center;max-width:680px;margin:0 auto 46px}
.section-head .kicker{font-size:.78rem;letter-spacing:2.5px;text-transform:uppercase;color:var(--rose);font-weight:600}
.section-head h2{font-size:clamp(2rem,5vw,2.9rem);margin:12px 0 14px}
.section-head p{color:var(--ink-soft);font-size:1.05rem}

/* ---------- tier cards ---------- */
.tiers{display:grid;grid-template-columns:1fr;gap:26px}
@media(min-width:620px){.tiers{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1000px){.tiers{grid-template-columns:repeat(3,1fr)}}
.tier{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-sm);
  transition:transform .18s ease,box-shadow .25s ease;position:relative;
}
.tier:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.tier.popular{border-color:var(--rose);box-shadow:0 22px 55px -24px rgba(168,71,95,.5)}
.tier .badge{
  position:absolute;top:14px;right:14px;z-index:2;background:var(--rose);color:#fff;
  font-size:.72rem;letter-spacing:1.2px;text-transform:uppercase;font-weight:700;
  padding:6px 12px;border-radius:999px;
}
.tier-body{padding:24px 24px 26px;display:flex;flex-direction:column;flex:1}
.tier h3{font-size:1.9rem;margin-bottom:4px}
.tier .price{font-family:'Jost',sans-serif;font-weight:600;font-size:1.5rem;color:var(--rose-deep);margin-bottom:12px}
.tier .price small{font-size:.8rem;color:var(--ink-soft);font-weight:500}
.tier .blurb{color:var(--ink-soft);font-size:.95rem;margin-bottom:16px;flex:1}
.tier .includes{list-style:none;margin:0 0 18px;padding:0;font-size:.88rem;color:var(--ink)}
.tier .includes li{display:flex;gap:8px;align-items:flex-start;margin-bottom:6px}
.tier .includes li::before{content:"✿";color:var(--sage);font-size:.9rem;line-height:1.5}
.tier .btn{margin-top:auto}

/* product image slot (CSS placeholder — SDXL fills later) */
.slot{position:relative;aspect-ratio:4/3;width:100%}
.slot .art{position:absolute;inset:0}
.slot figcaption{
  position:absolute;left:0;right:0;bottom:0;
  background:linear-gradient(0deg,rgba(43,38,32,.72),transparent);
  color:#fff;font-size:.74rem;letter-spacing:.3px;padding:18px 14px 10px;text-align:center;
}

/* ---------- selectors (palette / occasion) ---------- */
.choose{display:grid;grid-template-columns:1fr;gap:34px}
@media(min-width:820px){.choose{grid-template-columns:1fr 1fr}}
.choose h3{font-size:1.6rem;margin-bottom:6px}
.choose p.sub{color:var(--ink-soft);font-size:.95rem;margin-bottom:18px}
.chips{display:flex;flex-wrap:wrap;gap:12px}
.chip{
  border:1.5px solid var(--line);background:var(--card);border-radius:14px;
  padding:14px 18px;cursor:pointer;font-size:.95rem;font-weight:500;display:flex;align-items:center;gap:10px;
  transition:border-color .15s,box-shadow .15s,transform .12s;
}
.chip:hover{border-color:var(--blush);transform:translateY(-2px)}
.chip.active{border-color:var(--rose);box-shadow:0 0 0 3px rgba(194,91,115,.14)}
.chip .sw{width:18px;height:18px;border-radius:50%;flex:0 0 18px;border:1px solid rgba(0,0,0,.08)}
.sw-bright{background:linear-gradient(135deg,#f7b733,#ee5a6f,#9b5de5)}
.sw-romantic{background:linear-gradient(135deg,#f6d0d8,#e9b9c4,#c25b73)}
.sw-moody{background:linear-gradient(135deg,#6a3d5b,#4a6350,#2b2620)}
.sw-surprise{background:conic-gradient(#f7b733,#ee5a6f,#5f7a63,#9b5de5,#f7b733)}

/* ---------- policy / honesty band ---------- */
.policy{
  background:linear-gradient(180deg,#f4ece4,#fbf7f2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.policy .wrap{padding:60px 22px;text-align:center;max-width:820px}
.policy .mark{width:46px;height:46px;margin:0 auto 18px;color:var(--rose)}
.policy blockquote{font-family:'Cormorant Garamond',serif;font-size:clamp(1.4rem,3.6vw,2rem);font-style:italic;color:var(--ink);line-height:1.4}
.policy .who{margin-top:16px;font-size:.85rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--sage-deep);font-weight:600}

/* ---------- delivery explainer ---------- */
.delivery{display:grid;grid-template-columns:1fr;gap:22px}
@media(min-width:760px){.delivery{grid-template-columns:repeat(3,1fr)}}
.dcard{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-sm)}
.dcard .ic{width:34px;height:34px;color:var(--sage);margin-bottom:14px}
.dcard h4{font-family:'Cormorant Garamond',serif;font-size:1.5rem;margin-bottom:8px}
.dcard p{color:var(--ink-soft);font-size:.95rem}
.dcard .fee{display:inline-block;margin-top:12px;font-weight:600;color:var(--rose-deep)}

/* ---------- CTA band ---------- */
.cta-band{background:
  radial-gradient(120% 120% at 0% 0%,rgba(95,122,99,.4),transparent 55%),
  linear-gradient(135deg,var(--rose-deep),#7d3a4e);color:#fff;text-align:center}
.cta-band .wrap{padding:70px 22px}
.cta-band h2{font-size:clamp(2rem,5vw,2.8rem);margin-bottom:14px;color:#fff}
.cta-band p{color:rgba(255,255,255,.86);max-width:560px;margin:0 auto 26px;font-size:1.05rem}
.cta-band .btn-primary{background:#fff;color:var(--rose-deep)}
.cta-band .btn-primary:hover{background:#f7e9ec}
.cta-band .btn-ghost{border-color:rgba(255,255,255,.7);color:#fff}
.cta-band .btn-ghost:hover{background:rgba(255,255,255,.12)}
.cta-actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}

/* ---------- FAQ ---------- */
.faq-item{border:1px solid var(--line);border-radius:14px;background:var(--card);
  margin-bottom:14px;overflow:hidden;box-shadow:var(--shadow)}
.faq-item summary{list-style:none;cursor:pointer;padding:18px 22px;font-weight:600;
  font-size:1.05rem;display:flex;justify-content:space-between;align-items:center;gap:12px}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-family:'Jost',sans-serif;font-weight:400;
  font-size:1.5rem;color:var(--rose-deep);transition:transform .2s}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item p{padding:0 22px 20px;color:var(--ink-soft);line-height:1.65;font-size:.97rem}
.faq-item a{color:var(--rose-deep);font-weight:600;text-decoration:none}

/* ---------- footer ---------- */
footer{background:#241f1a;color:#cfc6ba;padding:54px 22px 34px}
.foot-grid{display:grid;grid-template-columns:1fr;gap:30px;max-width:var(--maxw);margin:0 auto 30px}
@media(min-width:760px){.foot-grid{grid-template-columns:1.4fr 1fr 1fr}}
.foot-grid h5{font-family:'Cormorant Garamond',serif;font-size:1.3rem;color:#fff;margin-bottom:12px}
.foot-grid a{color:#cfc6ba;text-decoration:none;display:block;margin-bottom:8px;font-size:.92rem}
.foot-grid a:hover{color:#fff}
.foot-grid p{font-size:.9rem;line-height:1.6}
.foot-cities{font-size:.86rem;color:#9a9088;line-height:1.7}
.foot-bottom{border-top:1px solid #3a332b;max-width:var(--maxw);margin:0 auto;padding-top:22px;
  display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;font-size:.82rem;color:#9a9088}
.foot-bottom a{color:#9a9088;text-decoration:none}
.foot-bottom a:hover{color:#fff}

/* ---------- sticky mobile call bar ---------- */
.callbar{
  position:fixed;left:0;right:0;bottom:0;z-index:60;display:flex;gap:10px;padding:10px 14px;
  background:rgba(251,247,242,.96);backdrop-filter:blur(10px);border-top:1px solid var(--line);
  box-shadow:0 -8px 24px -16px rgba(60,40,30,.4);
}
.callbar .btn{flex:1;padding:13px 16px;font-size:.98rem}
body{padding-bottom:74px}
@media(min-width:860px){.callbar{display:none}body{padding-bottom:0}}

/* ---------- generic page header (about/legal) ---------- */
.page-hero{background:linear-gradient(180deg,#fdf4ef,var(--cream));padding:64px 22px 40px;text-align:center}
.page-hero h1{font-size:clamp(2.2rem,6vw,3.4rem)}
.page-hero p{color:var(--ink-soft);max-width:620px;margin:14px auto 0}
.prose{max-width:740px;margin:0 auto;padding:48px 22px}
.prose p{margin-bottom:18px;color:#473f37;font-size:1.06rem}
.prose h2{font-size:1.9rem;margin:34px 0 12px}
.prose ul{margin:0 0 18px 20px}
.prose li{margin-bottom:8px;color:#473f37}
