/* ==========================================================
   styles.css — shared design system for flowerrentco.com
   Edit here; all pages update at once. Do NOT duplicate
   these rules inside individual page <style> blocks.
   ========================================================== */

/* === Fonts === */
@font-face{font-family:'PoynterDisplay';src:url('/fonts/PoynterOSDisp-Roman.ttf') format('truetype');font-weight:400;font-style:normal;font-display:swap;}
@font-face{font-family:'PoynterDisplay';src:url('/fonts/PoynterOSDisp-Italic.ttf') format('truetype');font-weight:400;font-style:italic;font-display:swap;}
@font-face{font-family:'HelveticaNow';src:url('/fonts/HelveticaNowDisplay-Medium.ttf') format('truetype');font-weight:300 600;font-style:normal;font-display:swap;}

/* === Design Tokens === */
:root{
  --sage:        #6b7750;
  --sage-dark:   #4a5437;
  --sage-mid:    #7d8f5e;
  --sage-light:  #b8c9a0;
  --sage-pale:   #eef2e6;
  --cream:       #faf8f2;
  --ivory:       #f5f1e8;
  --gold:        #b8a06a;
  --ink:         #1a1a1a;
  --ink-soft:    #4a4a4a;
  --ink-faded:   #8a8a8a;
  --line:        rgba(107,119,80,0.18);
  --shadow-sm:   0 2px 8px rgba(0,0,0,.06);
  --shadow-md:   0 8px 24px rgba(0,0,0,.10);
  --shadow-lg:   0 20px 60px rgba(0,0,0,.15);
  --serif:       'PoynterDisplay', Georgia, serif;
  --sans:        'HelveticaNow', 'Helvetica Neue', Arial, sans-serif;
  --container:   1280px;
}

/* === Reset === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
html,body{overflow-x:hidden;}
body{font-family:var(--sans);color:var(--ink);background:var(--cream);line-height:1.6;}

/* subtle background texture */
body::before{
  content:'';
  position:fixed;inset:0;
  background-image:
    radial-gradient(circle at 20% 30%,rgba(184,160,106,.03) 0%,transparent 50%),
    radial-gradient(circle at 80% 70%,rgba(107,119,80,.04) 0%,transparent 50%);
  pointer-events:none;
  z-index:1;
}

img{max-width:100%;height:auto;display:block;}
a{color:var(--sage);text-decoration:none;transition:color .3s;}
a:hover{color:var(--sage-dark);}

/* === Layout === */
.container{max-width:var(--container,1280px);margin:0 auto;padding:0 32px;position:relative;z-index:2;}

/* === Typography === */
h1{font-family:var(--serif);font-weight:400;line-height:1.06;color:var(--ink);}
h2{font-family:var(--serif);font-weight:400;font-size:clamp(28px,3.5vw,48px);line-height:1.12;color:var(--ink);margin-bottom:20px;}
h2 em{font-style:italic;color:var(--sage);}
h3{font-family:var(--serif);font-weight:400;font-size:clamp(18px,2vw,24px);color:var(--ink);margin-bottom:10px;}
p{color:var(--ink-soft);line-height:1.7;font-size:16px;margin-bottom:16px;}
p:last-child{margin-bottom:0;}

/* === Sections === */
section{padding:80px 0;}
section.alt{background:var(--ivory);}

/* eyebrow label above headings — works as .section-eyebrow or .eyebrow */
.section-eyebrow,.eyebrow{
  font-family:var(--sans);font-size:11px;font-weight:400;letter-spacing:.35em;
  text-transform:uppercase;color:var(--sage);margin-bottom:20px;
  display:inline-flex;align-items:center;gap:14px;
}
.section-eyebrow::before,.eyebrow::before{content:'';width:36px;height:1px;background:var(--sage);}

/* === Page hero (interior pages) === */
.page-hero{padding:160px 0 80px;background:var(--cream);}
.page-eyebrow{
  font-family:var(--sans);font-size:11px;font-weight:400;letter-spacing:.35em;
  text-transform:uppercase;color:var(--sage);margin-bottom:20px;
  display:inline-flex;align-items:center;gap:14px;
}
.page-eyebrow::before{content:'';width:36px;height:1px;background:var(--sage);}
.page-hero h1{font-family:var(--serif);font-weight:400;font-size:clamp(36px,5vw,68px);line-height:1.08;color:var(--ink);max-width:820px;}
.page-hero h1 em{font-style:italic;color:var(--sage);}
.page-hero .lead{font-size:18px;line-height:1.65;color:var(--ink-soft);max-width:620px;margin-top:24px;}

/* === Layout helpers === */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;}
.two-col.flip > *:first-child{order:2;}
.two-col.flip > *:last-child{order:1;}
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}

/* === CTA band (dark green strip) === */
.cta-band{background:var(--sage-dark);padding:80px 0;text-align:center;}
.cta-band h2{color:var(--cream);margin-bottom:16px;}
.cta-band h2 em{color:var(--sage-light);}
.cta-band p{color:rgba(250,248,242,.65);max-width:480px;margin:0 auto 36px;font-size:16px;}

/* === Buttons === */
.btn-cream{display:inline-flex;align-items:center;gap:12px;padding:15px 40px;background:var(--cream);color:var(--sage-dark);border-radius:100px;font-family:var(--sans);font-size:13px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;transition:background .2s,transform .2s;}
.btn-cream:hover{background:#fff;transform:translateY(-2px);}

.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;background:var(--sage);color:#fff;border-radius:100px;font-family:var(--sans);font-size:13px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;text-decoration:none;transition:background .2s,transform .2s;}
.btn-primary:hover{background:var(--sage-dark);color:#fff;transform:translateY(-1px);}

.btn-ghost{display:inline-flex;align-items:center;gap:8px;padding:13px 30px;background:transparent;color:var(--sage);border:1.5px solid var(--sage);border-radius:100px;font-family:var(--sans);font-size:13px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;text-decoration:none;transition:background .2s,color .2s,border-color .2s;}
.btn-ghost:hover{background:var(--sage);color:#fff;}

.btn-sage{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;background:var(--sage);color:#fff;border-radius:100px;font-family:var(--sans);font-size:13px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;text-decoration:none;transition:background .2s,transform .2s;}
.btn-sage:hover{background:var(--sage-dark);transform:translateY(-1px);}

/* === Utilities === */
a.address-link{color:inherit;text-decoration:underline;text-decoration-color:var(--sage-light);}
a.address-link:hover{color:var(--sage);}

/* scroll-reveal */
.observe{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease;}
.observe.in{opacity:1;transform:none;}
.observe-delay-1{transition-delay:.1s;}
.observe-delay-2{transition-delay:.2s;}
.observe-delay-3{transition-delay:.3s;}

/* === FAQ (shared across contact, how-it-works, service-areas, etc.) === */
.faq-list{display:flex;flex-direction:column;}
.faq-item{border-bottom:1px solid var(--line);}
.faq-q{width:100%;background:none;border:none;text-align:left;padding:20px 0;font-family:var(--serif);font-size:18px;color:var(--ink);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px;line-height:1.3;}
.faq-q::after{content:'+';font-size:22px;font-weight:300;color:var(--sage);flex-shrink:0;transition:transform .2s;}
.faq-item.open .faq-q::after,details[open] .faq-q::after{transform:rotate(45deg);}
.faq-a{display:none;padding:0 0 20px;}
.faq-item.open .faq-a{display:block;}
.faq-a-inner{font-size:15px;color:var(--ink-soft);line-height:1.7;}

/* === Responsive === */
@media(max-width:1024px){
  .two-col{gap:40px;}
}
@media(max-width:900px){
  .container{padding:0 20px;}
  .two-col{grid-template-columns:1fr;gap:40px;}
  .two-col.flip > *:first-child,.two-col.flip > *:last-child{order:unset;}
  .card-grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:960px){
  /* two-row nav is ~114px tall on mobile — give page-hero enough clearance */
  .page-hero{padding:140px 0 60px;}
}
@media(max-width:600px){
  .card-grid{grid-template-columns:1fr;}
  section{padding:60px 0;}
}
