/* Boston Flowers — Delivery Areas
   Requires: main.css, header-footer.css */

#hero{
  min-height:100vh;
  display:flex;
  align-items:center;
  padding:calc(var(--nav-h) + 80px) 0 140px;
  background:linear-gradient(135deg,#0d1f16 0%,#111315 28%,#0a1a10 58%,#111315 100%);
  background-size:400% 400%;
  animation:gradDrift 18s ease infinite;
  position:relative;
  overflow:hidden;
}
#hero::before{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,rgba(17,19,21,.18),rgba(17,19,21,.55));pointer-events:none}
.hero-word{position:absolute;left:50%;bottom:0;transform:translateX(-50%);font-family:'Cormorant Garamond',serif;font-size:clamp(140px,18vw,280px);letter-spacing:-.05em;line-height:1;color:var(--t1);opacity:.04;pointer-events:none;user-select:none;white-space:nowrap}
.hero-inner{position:relative;z-index:1;max-width:1280px;width:100%;margin:0 auto;padding:0 48px}
.hero-eyebrow{display:flex;align-items:center;gap:16px;margin-bottom:28px}
.hero-line{width:40px;height:1px;background:var(--rose)}
.hero-h1{font-size:clamp(46px,6vw,86px);font-weight:300;line-height:1.03;letter-spacing:-.02em;margin-bottom:18px;max-width:760px}
.hero-h1 em{font-style:italic;color:var(--rose)}
.hero-sub{font-size:16px;font-weight:300;line-height:1.8;color:var(--t2);max-width:620px;margin-bottom:34px}
.hero-actions{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-bottom:22px}
.hero-meta{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--stone)}

@keyframes marqueeL{0%{transform:translate3d(0,0,0)}100%{transform:translate3d(-50%,0,0)}}
@keyframes marqueeR{0%{transform:translate3d(-50%,0,0)}100%{transform:translate3d(0,0,0)}}
#trust-marquee{background:var(--olive-dim);border-top:1px solid var(--bd);border-bottom:1px solid var(--bd);padding:0;overflow:hidden}
.marquee-track{display:flex;overflow:hidden;padding:12px 0}
.marquee-inner{display:flex;white-space:nowrap;min-width:max-content;will-change:transform;animation:marqueeL 55s linear infinite;-webkit-animation:marqueeL 55s linear infinite}
.marquee-inner.rev{animation:marqueeR 50s linear infinite;-webkit-animation:marqueeR 50s linear infinite}
.marquee-item{font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--t2);padding:4px 32px;border-right:1px solid var(--bd);flex-shrink:0}
.marquee-item span{color:var(--rose);margin-right:10px}
@media(max-width:640px){
  .marquee-track{padding:10px 0}
  .marquee-inner{animation-duration:38s;-webkit-animation-duration:38s}
  .marquee-inner.rev{animation-duration:34s;-webkit-animation-duration:34s}
  .marquee-item{font-size:11px;letter-spacing:.18em;padding:4px 24px}
}

section{position:relative}
#zones{background:var(--ivory);padding:86px 0 72px}
.zones-head{margin-bottom:42px}
.zones-title{font-family:'Cormorant Garamond',serif;font-size:clamp(34px,4vw,52px);font-weight:300;line-height:1.1;color:var(--ink);margin-top:12px;max-width:540px}
.zones-title em{font-style:italic;color:var(--wine);}
.zone-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.zone-card{background:var(--ivory-dim);padding:30px;border:1px solid var(--bdl);transition:transform .25s,background .25s,border-color .25s}
.zone-card:hover{transform:translateY(-2px);background:var(--ivory);border-color:rgba(110,31,50,.18)}
.zone-tag{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--wine);margin-bottom:8px;display:block}
.zone-name{font-size:22px;font-weight:300;color:var(--ink);margin-bottom:4px}
.zone-price{font-size:30px;font-weight:300;color:var(--wine);margin-bottom:16px}
.zone-price span{font-family:'DM Sans',sans-serif;font-size:12px;font-weight:300;color:var(--stone)}
.city-list{display:flex;flex-wrap:wrap;gap:8px}
.city-chip{padding:5px 10px;border:1px solid var(--bdl);background:var(--ivory);font-size:13px;color:var(--stone)}
.not-listed{margin-top:28px;padding:24px 28px;background:var(--olive-dim);border:1px solid rgba(200,155,147,.2);display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}
.nl-title{font-size:24px;font-weight:300;color:var(--t1);margin-bottom:4px}
.nl-sub{font-size:13px;color:var(--t2);line-height:1.6}
.nl-btn{border:1px solid var(--rose);padding:11px 22px;font-size:13px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--rose);transition:.3s;white-space:nowrap}
.nl-btn:hover{background:var(--rose);color:var(--ink)}

#timing{background:linear-gradient(160deg,#151c18 0%,#171D1A 50%,#111513 100%);background-size:300% 300%;animation:gradDrift 28s ease infinite;padding:82px 0;border-top:1px solid var(--bd)}
.timing-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start}
.timing-title{font-size:clamp(34px,4vw,48px);font-weight:300;line-height:1.1;margin-top:12px}
.timing-title em{font-style:italic;color:var(--rose)}
.timing-sub{font-size:16px;color:var(--t2);line-height:1.8;margin-top:14px;max-width:360px}
.timing-steps{display:flex;flex-direction:column}
.timing-step{display:flex;gap:20px;padding:18px 0;border-top:1px solid var(--bd);transition:padding-left .25s}
.timing-step:last-child{border-bottom:1px solid var(--bd)}
.timing-step:hover{padding-left:8px}
.ts-time{min-width:76px;font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:300;color:var(--rose)}
.ts-name{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:400;color:var(--t1);margin-bottom:6px}
.ts-note{font-size:15px;color:var(--t2);line-height:1.7}

#faq{background:var(--ivory);padding:82px 0;border-top:1px solid var(--bdl)}
.faq-grid{display:grid;grid-template-columns:2fr 3fr;gap:68px;align-items:start}
.faq-title{font-size:clamp(32px,4vw,46px);font-weight:300;line-height:1.1;color:var(--ink);margin-top:12px}
.faq-title em{font-style:italic;color:var(--wine)}
.faq-list{display:flex;flex-direction:column}
.faq-item{border-bottom:1px solid var(--bdl);transition:padding-left .25s}
.faq-item.open{border-left:2px solid var(--wine);padding-left:14px;margin-left:-16px}
.faq-q{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:17px 0;font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:300;color:var(--ink);cursor:pointer;transition:color .25s}
.faq-q:hover,.faq-item.open .faq-q{color:var(--wine)}
.faq-icon{width:18px;height:18px;border:1px solid var(--bdl);display:flex;align-items:center;justify-content:center;color:var(--wine);font-size:12px;transition:transform .35s;flex-shrink:0}
.faq-item.open .faq-icon{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;font-size:16px;color:var(--stone);line-height:1.75;transition:max-height .35s ease,padding .35s ease}
.faq-item.open .faq-a{max-height:220px;padding-bottom:16px}

#cta{background:#3D0F1C;padding:96px 0;text-align:center;position:relative;overflow:hidden}
#cta::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 20% 50%,rgba(110,31,50,.65) 0%,transparent 55%),radial-gradient(ellipse at 80% 30%,rgba(80,15,30,.5) 0%,transparent 50%)}
#cta::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,transparent 0%,rgba(200,155,147,.05) 50%,transparent 100%);background-size:200% 200%;animation:gradDrift 22s ease infinite;pointer-events:none}
.cta-inner{position:relative;z-index:1}
.cta-title{font-size:clamp(32px,5vw,58px);font-weight:300;font-style:italic;color:var(--ivory);line-height:1.08;margin-bottom:14px}
.cta-sub{font-size:14px;color:rgba(243,238,231,.58);line-height:1.7;margin-bottom:12px}
.cta-send{font-size:13px;color:rgba(243,238,231,.35);letter-spacing:.04em;margin-bottom:34px}
.cta-btns{display:flex;justify-content:center;gap:14px;flex-wrap:wrap}

.footer-animated{background:linear-gradient(135deg,#0d1210 0%,#111315 40%,#0a1a10 70%,#111315 100%);background-size:400% 400%;animation:gradDrift 12s ease infinite;position:relative;padding:56px 0 28px;border-top:1px solid var(--bd);overflow:hidden;}
.footer-animated::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 30% 0%,rgba(110,31,50,.12) 0%,transparent 50%);pointer-events:none;}
.footer-animated::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(17,19,21,1) 0%,transparent 100%);pointer-events:none;}
.footer-animated .container{position:relative;z-index:1;}
.ft-grid{display:grid;grid-template-columns:1.8fr 1fr 1.35fr 1fr;gap:44px;margin-bottom:44px;}
.ft-col-contact{max-width:360px;}
.ft-logo{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:300;letter-spacing:.08em;color:var(--t1);margin-bottom:14px;display:flex;align-items:center;gap:10px;}
.ft-logo span{color:var(--rose);}
.ft-bf-mark{display:flex;align-items:flex-end;position:relative;width:28px;height:28px;flex-shrink:0;}
.ft-bf-b{font-family:'Cormorant Garamond',serif;font-size:26px;font-weight:300;color:var(--t1);line-height:1;position:absolute;left:0;top:0;}
.ft-bf-f{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:300;color:var(--rose) !important;line-height:1;position:absolute;left:13px;top:8px;opacity:.9;}
.ft-tag{font-size:13px;color:var(--t2);line-height:1.7;margin-bottom:26px;}
.ft-contact{list-style:none;display:flex;flex-direction:column;gap:14px;margin-bottom:26px;}
.ft-contact a{display:flex;align-items:center;gap:14px;color:var(--t1);text-decoration:none;transition:color .25s;}
.ft-contact a:hover{color:var(--rose);}
.ft-contact svg{width:18px;height:18px;flex-shrink:0;color:var(--rose);}
.ft-contact span{display:flex;flex-direction:column;line-height:1.3;font-size:13px;}
.ft-contact small{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--t2);margin-bottom:2px;font-weight:400;}
.ft-social{display:flex;gap:12px;align-items:center;}
.ft-soc-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid rgba(200,155,147,.2);color:var(--t2);text-decoration:none;transition:border-color .3s,color .3s;flex-shrink:0;}
.ft-soc-icon:hover{border-color:var(--rose);color:var(--rose);}
.ft-soc-icon svg{width:15px;height:15px;fill:currentColor;}
.ft-col-ttl{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--rose);margin-bottom:18px;font-weight:500;}
.ft-links{list-style:none;display:flex;flex-direction:column;gap:9px;}
.ft-links a{font-size:14px;color:var(--t2);text-decoration:none;transition:color .3s;}
.ft-links a:hover{color:var(--t1);}
.ft-col-ttl-sub{margin-top:28px;}
.ft-bottom{display:flex;align-items:flex-start;justify-content:space-between;padding-top:28px;border-top:1px solid var(--bd);flex-wrap:wrap;gap:18px;}
.ft-bottom-l{display:flex;flex-direction:column;gap:10px;}
.ft-bottom-r{display:flex;flex-direction:column;align-items:flex-end;gap:12px;}
.ft-minor{display:flex;gap:10px;align-items:center;flex-wrap:wrap;}
.ft-minor a{font-size:13px;color:var(--t2);text-decoration:none;transition:color .3s;}
.ft-minor a:hover{color:var(--t1);}
.ft-minor span{font-size:13px;color:var(--t2);opacity:.4;}
.ft-pay{display:flex;gap:8px;flex-wrap:wrap;}
.pay-badge{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border:1px solid rgba(200,155,147,.12);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--t2);font-family:'DM Sans',sans-serif;}
.ft-lang{font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--rose);text-decoration:none;transition:color .3s;}
.ft-lang:hover{color:var(--t1);}
.ft-copy{font-size:13px;color:var(--t2);}

.wa-float{position:fixed;bottom:24px;right:20px;z-index:400;width:48px;height:48px;border-radius:50%;background:var(--wine);display:flex;align-items:center;justify-content:center;box-shadow:0 3px 16px rgba(110,31,50,.35);opacity:0;transform:translateY(16px);transition:opacity .35s ease,transform .35s ease,background .3s;pointer-events:none}
.wa-float.visible{opacity:1;transform:translateY(0);pointer-events:all;animation:waFloat 3s ease-in-out 1s infinite}
.wa-float:hover{background:#8B2640;animation:none}
.wa-float svg{width:22px;height:22px;fill:#fff}

@media(max-width:1100px){
  .nav-menu{display:none;}.burger{display:flex;}
  nav{padding-left:max(20px,env(safe-area-inset-left));padding-right:max(20px,env(safe-area-inset-right));}
  .container,.hero-inner{padding:0 32px;}
  #hero{min-height:100svh;align-items:center;}
  .zone-grid,.timing-grid,.faq-grid{grid-template-columns:1fr;}
  .ft-grid{grid-template-columns:1fr 1fr;gap:32px;}
}
@media(max-width:640px){
  nav{padding-left:max(20px,env(safe-area-inset-left));padding-right:max(20px,env(safe-area-inset-right));}
  .container,.hero-inner{padding-left:max(20px,env(safe-area-inset-left));padding-right:max(20px,env(safe-area-inset-right));}
  #navCta{display:none;}.lang-switcher{display:none;}
  #hero{padding:calc(var(--nav-h) + 60px) 0 140px;min-height:100svh;align-items:center;}
  .hero-eyebrow{margin-bottom:14px;}
  .hero-h1{font-size:clamp(36px,9vw,52px) !important;max-width:none;}
  .hero-sub{font-size:15px !important;max-width:none;line-height:1.7;}
  .hero-actions{flex-direction:column;align-items:flex-start;gap:10px;}
  .hero-word{font-size:clamp(100px,24vw,160px);bottom:0;}
  .hero-meta{font-size:12px !important;letter-spacing:.12em !important;line-height:1.6;}
  .not-listed{flex-direction:column;align-items:flex-start;}
  .faq-item.open{margin-left:-10px;padding-left:10px;}
  .cta-btns{flex-direction:column;align-items:center;}
  .cta-btns .btn{width:100%;max-width:320px;}
  .ft-grid{grid-template-columns:1fr;gap:28px;}
  .ft-bottom{flex-direction:column;align-items:flex-start;gap:12px;}
  .ft-bottom-r{align-items:flex-start;}
  .ft-col-ttl{font-size:13px !important;letter-spacing:.16em;margin-bottom:14px;}
  .ft-links a{font-size:14px !important;line-height:1.6 !important;}
  .ft-copy,.ft-minor a,.ft-minor span{font-size:13px !important;}
  body,p,.hero-sub,.timing-sub,.nl-sub,.faq-a{font-size:15px !important;line-height:1.7 !important;}
  .lbl{font-size:12px !important;letter-spacing:.2em !important;}
  .ts-name{font-family:'Cormorant Garamond',serif !important;font-size:18px !important;}
  .ts-note{font-size:14px !important;line-height:1.7 !important;}
  .zone-name{font-family:'Cormorant Garamond',serif !important;font-size:22px !important;}
  .zone-price{font-size:24px !important;}
  .faq-q{font-family:'Cormorant Garamond',serif !important;font-size:clamp(16px,4.5vw,19px) !important;}
  .m-cta .nav-cta{min-width:200px !important;padding:14px 32px !important;display:block;text-align:center;width:100%;}
}
@media(max-width:1100px) and (orientation:landscape) and (min-width:640px){
  html,body{width:100vw;max-width:100vw;overflow-x:hidden;}
  section,footer,.footer-animated{width:100%;max-width:100vw;}
  .container,.hero-inner{width:100%;max-width:100%;padding-left:5vw;padding-right:5vw;}
  #hero{min-height:100lvh !important;padding-top:calc(var(--nav-h) + 40px) !important;padding-bottom:100px !important;align-items:flex-start !important;}
  .hero-word{font-size:clamp(60px,12vw,120px) !important;bottom:0 !important;opacity:.03 !important;left:auto !important;right:5vw !important;transform:none !important;}
  .hero-h1{font-size:clamp(28px,4.5vw,46px) !important;margin-bottom:10px !important;}
  .hero-sub{font-size:13px !important;margin-bottom:12px !important;}
  .hero-actions{margin-bottom:16px !important;}
  .hero-meta{margin-bottom:0 !important;}
}
html,body{margin:0;padding:0;overflow-x:hidden;}
section,footer,.footer-animated{width:100%;max-width:100%;}
/* MONOGRAM FORCE — пробить любой cascade */
.bf-b,.ft-bf-b{color:var(--ivory)!important;-webkit-text-fill-color:var(--ivory)!important;}
.bf-f,.ft-bf-f{color:var(--rose) !important;-webkit-text-fill-color:var(--rose) !important;}
.nav-logo .bf-f{color:var(--rose) !important;-webkit-text-fill-color:var(--rose) !important;}
.ft-logo .ft-bf-f{color:var(--rose) !important;-webkit-text-fill-color:var(--rose) !important;}

/* FINAL HERO FRONT-PAGE RHYTHM + NO OBSERVER JITTER */
#hero .hero-eyebrow{margin-bottom:32px;opacity:0;animation:fadeUp 1s ease .3s forwards;}
#hero .hero-h1{margin-bottom:28px;opacity:0;animation:fadeUp 1s ease .5s forwards;}
#hero .hero-sub{margin-bottom:48px;opacity:0;animation:fadeUp 1s ease .7s forwards;}
#hero .hero-actions{gap:20px;margin-bottom:24px;opacity:0;animation:fadeUp 1s ease .9s forwards;}
#hero .hero-meta{opacity:0;animation:fadeUp 1s ease 1s forwards;}
@media(max-width:640px){
  #hero .hero-eyebrow{margin-bottom:22px;}
  #hero .hero-h1{margin-bottom:24px;}
  #hero .hero-sub{margin-bottom:34px;}
  #hero .hero-actions{gap:12px;}
}
@media(max-width:1100px) and (orientation:landscape) and (min-width:640px){
  #hero .hero-eyebrow{margin-bottom:32px !important;}
  #hero .hero-h1{margin-bottom:28px !important;}
  #hero .hero-sub{margin-bottom:40px !important;}
  #hero .hero-actions{gap:20px !important;margin-bottom:24px !important;}
}
