/* ============================================
   Sugar Strategist — Design System
   Palette: charcoal / taupe (primary) + gold (precision accent) + teal (action accent)
   ============================================ */

:root{
  --ink:#494848;
  --ink-soft:#6E6C6C;
  --taupe-light:#E4DCCF;
  --taupe-dark:#B8ADA0;
  --white:#FFFFFF;
  --gold:#C8A96A;
  --gold-soft:rgba(200,169,106,0.18);
  --teal:#008E89;
  --teal-light:#00BFB4;
  --line: rgba(73,72,72,0.14);
  --line-on-dark: rgba(228,220,207,0.2);
  --shadow: 0 12px 32px rgba(73,72,72,0.10);
}

*{box-sizing:border-box; margin:0; padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  background:var(--white);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  font-size:16px;
}
h1,h2,h3,h4{
  font-family:'Fraunces', Georgia, serif;
  font-weight:600;
  line-height:1.12;
  letter-spacing:-0.01em;
  color:var(--ink);
}
a{color:inherit; text-decoration:none;}
img{max-width:100%; display:block;}
ul{list-style:none;}
button{font-family:inherit; cursor:pointer;}

.wrap{max-width:1180px; margin:0 auto; padding:0 32px;}
section{padding:110px 0;}
@media(max-width:640px){ section{padding:72px 0;} .wrap{padding:0 22px;} }

/* ---- Signature section marker ---- */
.marker{display:flex; align-items:center; gap:12px; margin-bottom:20px;}
.marker .sq{width:7px; height:7px; background:var(--gold); transform:rotate(45deg); flex:none;}
.marker .rule{height:1px; width:48px; background:var(--gold); flex:none;}
.marker .label{
  font-family:'IBM Plex Mono', monospace; font-size:0.72rem; font-weight:500;
  letter-spacing:0.16em; text-transform:uppercase; color:var(--ink-soft);
}
.marker.on-dark .label{color:var(--taupe-light);}

.sec-head{max-width:680px; margin-bottom:56px;}
.sec-head h2{font-size:clamp(1.9rem, 3.6vw, 2.75rem);}
.sec-head p{margin-top:18px; font-size:1.08rem; color:var(--ink-soft); max-width:60ch;}

/* ---- Buttons ---- */
.btn{
  display:inline-block; padding:15px 30px; font-weight:600; font-size:0.9rem;
  letter-spacing:0.01em; border-radius:1px; transition:all .18s ease; white-space:nowrap;
}
.btn-teal{background:var(--teal); color:var(--white);}
.btn-teal:hover{background:var(--teal-light); transform:translateY(-1px);}
.btn-outline{border:1.5px solid var(--ink); color:var(--ink);}
.btn-outline:hover{background:var(--ink); color:var(--white);}
.btn-outline-dark{border:1.5px solid var(--line-on-dark); color:var(--taupe-light);}
.btn-outline-dark:hover{border-color:var(--taupe-light);}

/* ---- Nav ---- */
#nav{
  position:sticky; top:0; z-index:100;
  background:rgba(255,255,255,0.92); backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
#nav .wrap{display:flex; align-items:center; justify-content:space-between; padding:18px 32px;}
.logo-lockup{display:flex; align-items:center; gap:10px;}
.logo-lockup img{height:34px; width:auto;}
.logo-lockup .wordmark{font-family:'Fraunces'; font-weight:600; font-size:1.05rem; letter-spacing:0.01em;}
.navlinks{display:none; gap:32px; align-items:center;}
@media(min-width:900px){ .navlinks{display:flex;} }
.navlinks a{font-size:0.88rem; font-weight:500; color:var(--ink); position:relative; padding-bottom:4px;}
.navlinks a::after{content:""; position:absolute; left:0; right:100%; bottom:0; height:1px; background:var(--teal); transition:right .2s ease;}
.navlinks a:hover::after, .navlinks a.active::after{right:0;}
.navlinks a.active{color:var(--teal);}
.nav-cta{display:none;}
@media(min-width:900px){ .nav-cta{display:inline-block;} }
.nav-toggle{background:none; border:1px solid var(--ink); padding:8px 12px; font-family:'IBM Plex Mono'; font-size:0.7rem; letter-spacing:0.1em;}
@media(min-width:900px){ .nav-toggle{display:none;} }
#mobileMenu{display:none; border-bottom:1px solid var(--line); background:var(--white);}
#mobileMenu.open{display:block;}
#mobileMenu .wrap{display:flex; flex-direction:column; gap:0; padding:0 32px;}
#mobileMenu a{padding:16px 0; border-bottom:1px solid var(--line); font-size:0.95rem;}
#mobileMenu a:last-child{border-bottom:none;}

/* ---- Hero ---- */
.hero{
  position:relative; background:var(--ink); color:var(--taupe-light);
  padding:150px 0 90px; overflow:hidden;
}
.hero-bg{
  position:absolute; inset:0; z-index:0;
  background-image:linear-gradient(105deg, rgba(73,72,72,0.95) 0%, rgba(73,72,72,0.88) 40%, rgba(73,72,72,0.62) 100%), var(--hero-img, none);
  background-size:cover; background-position:center;
}
.hero .wrap{position:relative; z-index:1;}
.hero h1{font-size:clamp(2.5rem, 5.4vw, 4.2rem); max-width:16ch; margin-bottom:26px;}
.hero h1 em{font-style:italic; color:var(--gold); font-weight:500;}
.hero .lede{font-size:1.15rem; max-width:54ch; color:rgba(228,220,207,0.85); margin-bottom:40px;}
.hero-ctas{display:flex; gap:16px; flex-wrap:wrap; margin-bottom:64px;}
.hero .btn{padding:17px 32px; font-size:0.92rem;}
.stat-row{display:flex; gap:48px; flex-wrap:wrap; border-top:1px solid var(--line-on-dark); padding-top:30px;}
.stat{display:flex; flex-direction:column; gap:4px;}
.stat .num{font-family:'IBM Plex Mono'; font-size:1.5rem; font-weight:600; color:var(--gold);}
.stat .lbl{font-family:'IBM Plex Mono'; font-size:0.68rem; letter-spacing:0.08em; text-transform:uppercase; color:rgba(228,220,207,0.6);}

/* ---- Page header (for interior pages) ---- */
.page-header{background:var(--ink); color:var(--taupe-light); padding:130px 0 70px;}
.page-header h1{font-size:clamp(2.1rem, 4vw, 3.2rem); max-width:20ch;}
.page-header p{margin-top:18px; font-size:1.05rem; color:rgba(228,220,207,0.82); max-width:60ch;}

/* ---- Cards / grids ---- */
.grid-2{display:grid; grid-template-columns:1fr 1fr; gap:28px;}
.grid-3{display:grid; grid-template-columns:repeat(3,1fr); gap:24px;}
.grid-4{display:grid; grid-template-columns:repeat(4,1fr); gap:20px;}
@media(max-width:900px){ .grid-3{grid-template-columns:1fr 1fr;} .grid-4{grid-template-columns:1fr 1fr;} }
@media(max-width:640px){ .grid-2{grid-template-columns:1fr;} .grid-3{grid-template-columns:1fr;} .grid-4{grid-template-columns:1fr;} }

.card{background:var(--white); border:1px solid var(--line); padding:34px; box-shadow:var(--shadow);}
.card-flat{border:1px solid var(--line); padding:34px;}

/* ---- Photo card (who we help) ---- */
.photo-card{position:relative; overflow:hidden; aspect-ratio:4/5; border:1px solid var(--line);}
.photo-card img{width:100%; height:100%; object-fit:cover; transition:transform .5s ease;}
.photo-card:hover img{transform:scale(1.06);}
.photo-card-label{
  position:absolute; left:0; right:0; bottom:0; padding:22px 18px 16px;
  background:linear-gradient(0deg, rgba(73,72,72,0.92) 0%, rgba(73,72,72,0.4) 65%, transparent 100%);
  color:var(--taupe-light);
}
.photo-card-label h4{font-size:1.05rem; color:var(--white); margin-bottom:4px;}
.photo-card-label p{font-size:0.78rem; color:rgba(228,220,207,0.85);}

/* ---- Services list ---- */
.service-row{
  display:grid; grid-template-columns:220px 1fr; gap:36px;
  padding:34px 0; border-bottom:1px solid var(--line);
}
@media(max-width:760px){ .service-row{grid-template-columns:1fr; gap:10px;} }
.service-row .num{font-family:'IBM Plex Mono'; font-size:0.72rem; letter-spacing:0.1em; color:var(--gold); text-transform:uppercase; padding-top:5px;}
.service-row h3{font-size:1.35rem; margin-bottom:10px;}
.service-row p{color:var(--ink-soft); max-width:62ch;}

/* ---- About / founders ---- */
.founder-card{background:var(--white); border:1px solid var(--line); padding:36px; box-shadow:var(--shadow);}
.founder-photo{width:96px; height:96px; border-radius:50%; object-fit:cover; margin-bottom:20px; border:3px solid var(--taupe-light);}
.founder-card .role{font-family:'IBM Plex Mono'; font-size:0.7rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--teal); margin-bottom:8px; display:block;}
.founder-card h3{font-size:1.4rem; margin-bottom:14px;}
.founder-card p{color:var(--ink-soft);}

.moments{display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:48px;}
@media(max-width:700px){ .moments{grid-template-columns:1fr;} }
.moment{position:relative; overflow:hidden; border:1px solid var(--line);}
.moment img{width:100%; height:200px; object-fit:cover; transition:transform .5s ease;}
.moment:hover img{transform:scale(1.06);}
.moment span{
  position:absolute; bottom:0; left:0; right:0; padding:12px 14px;
  background:linear-gradient(0deg, rgba(73,72,72,0.85), transparent);
  color:var(--white); font-family:'IBM Plex Mono'; font-size:0.68rem; letter-spacing:0.04em;
}

/* ---- Testimonials ---- */
.tix-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:22px;}
@media(max-width:920px){ .tix-grid{grid-template-columns:1fr 1fr;} }
@media(max-width:640px){ .tix-grid{grid-template-columns:1fr;} }
.tix{background:var(--ink); border:1px solid rgba(228,220,207,0.1); padding:30px; display:flex; flex-direction:column; gap:16px;}
.tix-logo{max-height:38px; max-width:150px; width:auto; margin-bottom:6px;}
.tix p{font-size:0.92rem; color:rgba(228,220,207,0.9); flex-grow:1;}
.tix .who{font-family:'IBM Plex Mono'; font-size:0.72rem; color:var(--gold); letter-spacing:0.03em;}
.tix .who span{display:block; color:rgba(228,220,207,0.55); margin-top:2px;}

/* ---- Pricing ---- */
.price-group-label{font-family:'IBM Plex Mono'; font-size:0.75rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--teal); margin:52px 0 22px;}
.price-group-label:first-of-type{margin-top:0;}
.price-card{background:var(--white); border:1px solid var(--line); padding:30px; display:flex; flex-direction:column; box-shadow:var(--shadow);}
.price-card.featured{border:1.5px solid var(--gold); position:relative;}
.price-card.featured::before{
  content:"BEST VALUE"; font-family:'IBM Plex Mono'; font-size:0.62rem; letter-spacing:0.08em;
  background:var(--gold); color:var(--ink); padding:4px 10px; position:absolute; top:-12px; left:26px;
}
.price-card h4{font-size:1.1rem; margin-bottom:6px;}
.price-card .amount{font-family:'IBM Plex Mono'; font-size:1.7rem; font-weight:600; color:var(--teal); margin-bottom:4px;}
.price-card .note{font-size:0.82rem; color:var(--ink-soft); margin-bottom:20px;}
.price-card ul{display:flex; flex-direction:column; gap:9px; font-size:0.87rem; color:var(--ink-soft); flex-grow:1; margin-bottom:20px;}
.price-card ul li{padding-left:16px; position:relative;}
.price-card ul li::before{content:"—"; position:absolute; left:0; color:var(--gold);}

/* ---- FAQ ---- */
.faq-item{border-bottom:1px solid var(--line);}
.faq-q{
  width:100%; text-align:left; background:none; border:none; padding:24px 0;
  display:flex; justify-content:space-between; align-items:center; gap:20px;
  font-family:'Fraunces'; font-size:1.1rem; font-weight:600; color:var(--ink);
}
.faq-q .plus{font-family:'IBM Plex Mono'; font-size:1.3rem; color:var(--teal); transition:transform .2s; flex:none;}
.faq-item.open .plus{transform:rotate(45deg);}
.faq-a{max-height:0; overflow:hidden; transition:max-height .25s ease;}
.faq-a p{padding-bottom:24px; color:var(--ink-soft); max-width:70ch;}

/* ---- Blog ---- */
.blog-card{border-bottom:1px solid var(--line); padding:30px 0;}
.blog-card .cat{font-family:'IBM Plex Mono'; font-size:0.68rem; letter-spacing:0.08em; text-transform:uppercase; color:var(--teal); margin-bottom:10px; display:block;}
.blog-card h3{font-size:1.3rem; margin-bottom:10px;}
.blog-card p{color:var(--ink-soft);}

/* ---- CTA band ---- */
.cta-band{background:var(--ink); color:var(--taupe-light); text-align:center;}
.cta-band h2{color:var(--white); font-size:clamp(1.9rem,4vw,2.7rem); max-width:18ch; margin:0 auto 20px;}
.cta-band p{max-width:50ch; margin:0 auto 36px; color:rgba(228,220,207,0.85); font-size:1.05rem;}

/* ---- Contact form ---- */
.contact-form{max-width:640px; margin:0 auto; text-align:left;}
.form-row{display:grid; grid-template-columns:1fr 1fr; gap:16px;}
@media(max-width:560px){ .form-row{grid-template-columns:1fr;} }
.form-field{margin-bottom:18px;}
.contact-form label{
  display:block; font-family:'IBM Plex Mono'; font-size:0.7rem; letter-spacing:0.06em;
  text-transform:uppercase; color:rgba(228,220,207,0.85); margin-bottom:7px;
}
.contact-form input, .contact-form textarea, .contact-form select{
  width:100%; padding:13px 14px; border:1px solid rgba(228,220,207,0.3);
  background:rgba(228,220,207,0.07); color:var(--taupe-light); font-family:'Inter'; font-size:0.95rem;
  border-radius:1px; resize:vertical;
}
.contact-form input::placeholder, .contact-form textarea::placeholder{color:rgba(228,220,207,0.4);}
.contact-form input:focus, .contact-form textarea:focus, .contact-form select:focus{
  outline:none; border-color:var(--gold); background:rgba(228,220,207,0.12);
}
.form-note{font-size:0.78rem; color:rgba(228,220,207,0.6); margin-top:16px;}

/* ---- Footer ---- */
footer{background:var(--ink); color:rgba(228,220,207,0.6); padding:56px 0 32px; font-size:0.85rem;}
.footer-grid{display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:32px; margin-bottom:40px;}
@media(max-width:760px){ .footer-grid{grid-template-columns:1fr 1fr;} }
.footer-grid h5{font-family:'IBM Plex Mono'; font-size:0.7rem; letter-spacing:0.08em; text-transform:uppercase; color:var(--taupe-light); margin-bottom:16px;}
.footer-grid a{display:block; padding:6px 0; color:rgba(228,220,207,0.65);}
.footer-grid a:hover{color:var(--gold);}
.footer-bottom{display:flex; justify-content:space-between; flex-wrap:wrap; gap:16px; align-items:center; border-top:1px solid var(--line-on-dark); padding-top:24px;}

/* ---- Scroll reveal (subtle, consistent, applied to section markers/headings only) ---- */
.reveal{opacity:0; transform:translateY(18px); transition:opacity .6s ease, transform .6s ease;}
.reveal.in-view{opacity:1; transform:translateY(0);}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1; transform:none; transition:none;}
}
