/* FabrizioTech — shared product page styles
   Used by: beacon, canopy, tapestry, sova, lighthouse, legacy, celestia
   Not used by: index.html (homepage has its own inline styles for the
   distinct two-tier layout)

   Page-specific extensions can be added in an inline <style> block
   underneath the <link> tag in any individual page. */

:root {
  --bg:#12091A;--bg-up:#1A0F24;--bg-card:#251636;--bg-card-h:#2E1C42;
  --bdr:rgba(183,110,121,0.12);--bdr-h:rgba(183,110,121,0.35);
  --wine:#8C3A56;--rose:#B76E79;--rose-g:#C9848E;--rose-l:#D4A0A8;
  --cream:#F4ECE6;--tx:#EDE5DF;--tx-d:rgba(237,229,223,0.55);--tx-f:rgba(237,229,223,0.3);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Outfit',sans-serif;font-weight:300;color:var(--tx);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}

/* NAV */
nav{position:fixed;top:0;width:100%;z-index:100;background:rgba(18,9,26,0.9);backdrop-filter:blur(20px);border-bottom:1px solid var(--bdr)}
.ni{max-width:1200px;margin:0 auto;padding:1.4rem 2.5rem;display:flex;justify-content:space-between;align-items:center}
.logo{font-size:0.85rem;font-weight:500;color:var(--tx);text-decoration:none;text-transform:uppercase;letter-spacing:0.35em}
.logo span{color:var(--rose)}
.nl{display:flex;gap:2.5rem;list-style:none;align-items:center}
.nl a{font-size:0.7rem;font-weight:400;color:var(--tx-d);text-decoration:none;text-transform:uppercase;letter-spacing:0.2em;transition:color 0.3s}
.nl a:hover{color:var(--rose-l)}
.nc{color:var(--cream)!important;border:1px solid var(--rose);padding:0.55rem 1.6rem;transition:all 0.3s!important}
.nc:hover{background:var(--rose);color:var(--bg)!important}
.hb{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px}
.hb i{width:22px;height:1.5px;background:var(--tx-d);display:block}

/* HERO */
.hero{padding:10rem 2.5rem 6rem;max-width:900px;margin:0 auto}
.he{font-size:0.65rem;font-weight:500;text-transform:uppercase;letter-spacing:0.35em;color:var(--rose);margin-bottom:1.5rem}
.hero h1{font-family:'Playfair Display',serif;font-size:clamp(2.4rem,5vw,3.8rem);font-weight:400;color:var(--cream);line-height:1.1;margin-bottom:1.5rem}
.hero h1 em{font-style:italic;color:var(--rose-l)}
.hero-p{font-size:1rem;color:var(--tx-d);max-width:600px;line-height:1.7;margin-bottom:2.5rem}
.cta{display:inline-block;font-size:0.72rem;font-weight:500;text-transform:uppercase;letter-spacing:0.25em;color:var(--bg);background:linear-gradient(135deg,var(--rose) 0%,var(--rose-g) 100%);padding:1.1rem 3rem;text-decoration:none;transition:all 0.4s}
.cta:hover{transform:translateY(-2px);box-shadow:0 15px 40px rgba(183,110,121,0.2)}
.cta-o{background:none;border:1px solid var(--rose);color:var(--cream)}
.cta-o:hover{background:var(--rose);color:var(--bg);box-shadow:none}

/* SECTIONS */
.sec{padding:6rem 2.5rem}
.si{max-width:1000px;margin:0 auto}
.se{font-size:0.65rem;font-weight:500;text-transform:uppercase;letter-spacing:0.35em;color:var(--rose);margin-bottom:1.2rem}
.st{font-family:'Playfair Display',serif;font-size:clamp(1.6rem,3vw,2.4rem);font-weight:400;color:var(--cream);margin-bottom:1.5rem}
.divider{border:none;border-top:1px solid var(--bdr);margin:0}

/* FEATURES */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2.5rem;margin-top:3rem}
.feat h3{font-size:0.68rem;font-weight:500;text-transform:uppercase;letter-spacing:0.25em;color:var(--rose-g);margin-bottom:0.8rem}
.feat p{font-size:0.85rem;color:var(--tx-d);line-height:1.65}
.feat-line{width:30px;height:1px;background:var(--rose);margin-bottom:1.5rem}

/* BEFORE / AFTER */
.ba{background:var(--bg-up);border-top:1px solid var(--bdr);border-bottom:1px solid var(--bdr)}
.ba-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;margin-top:3rem}
.ba-col h3{font-size:0.68rem;font-weight:500;text-transform:uppercase;letter-spacing:0.25em;margin-bottom:1.5rem}
.ba-col.before h3{color:var(--tx-f)}
.ba-col.after h3{color:var(--rose-g)}
.ba-col p{font-size:0.85rem;color:var(--tx-d);line-height:2;font-weight:300}
.ba-col.after p{color:var(--tx)}

/* PROCESS / STEPS */
.steps{margin-top:3rem;display:flex;flex-direction:column;gap:2.5rem}
.step{display:flex;gap:2rem;align-items:flex-start}
.step-num{font-family:'Playfair Display',serif;font-size:2rem;color:var(--rose);line-height:1;min-width:40px}
.step h3{font-size:0.85rem;font-weight:500;color:var(--cream);margin-bottom:0.4rem}
.step p{font-size:0.85rem;color:var(--tx-d);line-height:1.6}

/* PRICING */
.pricing{text-align:center;background:var(--bg-card);border-top:1px solid var(--bdr);border-bottom:1px solid var(--bdr)}
.price{font-family:'Playfair Display',serif;font-size:3.5rem;font-weight:400;color:var(--cream);margin:1.5rem 0 0.5rem}
.price-note{font-size:0.72rem;color:var(--tx-f);text-transform:uppercase;letter-spacing:0.15em;margin-bottom:2rem}
.includes{list-style:none;text-align:left;max-width:500px;margin:0 auto 3rem;display:flex;flex-direction:column;gap:0.8rem}
.includes li{font-size:0.85rem;color:var(--tx-d);padding-left:1.5rem;position:relative}
.includes li::before{content:'—';position:absolute;left:0;color:var(--rose)}

/* FAQ */
.faq-list{margin-top:3rem;display:flex;flex-direction:column;gap:0}
.faq-item{border-bottom:1px solid var(--bdr);padding:1.8rem 0}
.faq-item:first-child{border-top:1px solid var(--bdr)}
.faq-q{font-size:0.95rem;font-weight:400;color:var(--cream);cursor:pointer;display:flex;justify-content:space-between;align-items:center}
.faq-q::after{content:'+';font-size:1.2rem;color:var(--rose);transition:transform 0.3s}
.faq-item.open .faq-q::after{transform:rotate(45deg)}
.faq-a{font-size:0.85rem;color:var(--tx-d);line-height:1.7;max-height:0;overflow:hidden;transition:max-height 0.4s ease,padding 0.4s ease;padding-top:0}
.faq-item.open .faq-a{max-height:200px;padding-top:1rem}

/* CTA SECTION */
.cta-sec{text-align:center;padding:6rem 2.5rem}
.cta-sec h2{font-family:'Playfair Display',serif;font-size:clamp(1.6rem,3vw,2.2rem);font-weight:400;color:var(--cream);margin-bottom:1rem}
.cta-sec p{font-size:0.88rem;color:var(--tx-d);margin-bottom:2.5rem}

/* SHARED COMPONENTS */
/* ROI callout — used by canopy, tapestry */
.roi{background:var(--bg-card);border:1px solid var(--bdr);border-left:3px solid var(--rose);padding:2rem 2.5rem;margin-top:3rem}
.roi p{font-size:0.95rem;color:var(--tx);font-weight:400;line-height:1.7}
.roi strong{color:var(--rose-l)}

/* Centered italic callout — used by tapestry */
.callout{background:var(--bg-card);border-top:1px solid var(--bdr);border-bottom:1px solid var(--bdr);text-align:center;padding:5rem 2.5rem}
.callout h2{font-family:'Playfair Display',serif;font-size:clamp(1.6rem,3vw,2.4rem);font-weight:400;color:var(--cream);margin-bottom:1rem;font-style:italic}
.callout p{font-size:0.92rem;color:var(--tx-d);max-width:600px;margin:0 auto;line-height:1.8}

/* Upsell card — used by celestia */
.upsell{background:var(--bg-card);border:1px solid var(--bdr);border-left:3px solid var(--rose);padding:2rem 2.5rem;max-width:500px;margin:2.5rem auto 0;text-align:left}
.upsell p{font-size:0.85rem;color:var(--tx-d);line-height:1.7}
.upsell a{color:var(--rose-l);text-decoration:none;font-weight:400;transition:color 0.3s}
.upsell a:hover{color:var(--rose)}

/* PROOF — subtle live-product screenshots from real clients */
.proof{padding:5rem 2.5rem;text-align:center;border-top:1px solid var(--bdr)}
.proof-grid{display:flex;justify-content:center;gap:2rem;flex-wrap:wrap;max-width:780px;margin:2.5rem auto 0}
.proof-grid figure{margin:0;display:flex;flex-direction:column;align-items:center;flex:0 1 320px}
.proof-grid img{width:100%;max-width:320px;border:1px solid var(--bdr);transition:border-color 0.4s;display:block}
.proof-grid img:hover{border-color:var(--bdr-h)}
.proof-cap{margin-top:1rem;font-size:0.65rem;font-weight:400;color:var(--tx-f);text-transform:uppercase;letter-spacing:0.25em}

/* FOOTER */
footer{border-top:1px solid var(--bdr);padding:3rem 2.5rem;text-align:center}
footer p{font-size:0.72rem;color:var(--tx-f)}
footer a{color:var(--tx-d);text-decoration:none;transition:color 0.3s}
footer a:hover{color:var(--rose-l)}

/* REVEAL ANIMATION */
.rv{opacity:0;transform:translateY(25px);transition:opacity 0.7s ease,transform 0.7s ease}
.rv.v{opacity:1;transform:translateY(0)}

/* RESPONSIVE */
@media(max-width:900px){
  .feat-grid{grid-template-columns:1fr}
  .ba-grid{grid-template-columns:1fr;gap:2rem}
  .nl{display:none}
  .hb{display:flex}
  .nl.open{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:rgba(18,9,26,0.97);padding:2rem 2.5rem;gap:1.5rem;border-bottom:1px solid var(--bdr)}
}
@media(max-width:600px){
  .hero{padding:8rem 1.5rem 4rem}
  .sec{padding:4rem 1.5rem}
  .proof{padding:4rem 1.5rem}
}
