/* ==============================
   Trimthefee — design tokens
   ============================== */
:root{
  /* Palette */
  --page: #F7F6F2;
  --page-alt: #F1EFEA;
  --card-grey: #EFEEEA;
  --footer-bg: #EFF3F6;
  --ink: #111111;
  --ink-2: #1A1A1A;
  --muted: #8A8A8A;
  --muted-2: #6B6B6B;
  --line: #E7E5DF;

  --blue-bg: #E1F1FB;
  --blue: #1E8FD9;
  --blue-ink: #0C6DB0;

  --pink-bg: #FFD9EC;
  --pink: #D63384;

  --lav-bg: #E6DFFF;
  --lav: #7A5CFF;

  --star: #F68A2C;

  /* Brand accent */
  --accent: #FF3131;
  --accent-soft: #FFE2E2;
  --accent-ink: #C21A1A;

  --white: #FFFFFF;
  --black: #0E0E0E;

  /* Type */
  --f-sans: 'Inter', 'Söhne', 'GT America', -apple-system, BlinkMacSystemFont, system-ui, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
  --f-script: 'Caveat', 'Homemade Apple', cursive;

  /* Radii */
  --r-xs: 8px;
  --r-sm: 12px;
  --r-md: 16px;
  --r-lg: 20px;
  --r-xl: 28px;
  --r-pill: 9999px;

  /* Shadows */
  --shadow-sm: 0 1px 2px rgba(0,0,0,.04), 0 2px 4px rgba(0,0,0,.04);
  --shadow-md: 0 4px 10px rgba(0,0,0,.05), 0 12px 30px rgba(0,0,0,.06);
  --shadow-lg: 0 10px 30px rgba(0,0,0,.08), 0 30px 70px rgba(0,0,0,.12);
  --shadow-nav: 0 2px 10px rgba(0,0,0,.05), 0 8px 24px rgba(0,0,0,.06);

  /* Layout */
  --maxw: 1120px;
  --gutter: clamp(16px, 3.5vw, 32px);
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family: var(--f-sans);
  color: var(--ink);
  background: var(--page);
  font-size: 16px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}
img,svg,video{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}

/* Layout */
.container{
  width:100%;
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 0 var(--gutter);
}
.container-wide{
  width:100%;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 var(--gutter);
}

/* Type scale */
.eyebrow{
  display:inline-flex;align-items:center;justify-content:center;
  background: var(--blue-bg);
  color: var(--blue-ink);
  font-weight:500;
  font-size:14px;
  letter-spacing:-.005em;
  padding:8px 16px;
  border-radius: var(--r-pill);
}
h1,h2,h3,h4{margin:0;letter-spacing:-0.025em;font-weight:600;color:var(--ink)}
.h-display{
  font-size: clamp(40px, 5vw, 72px);
  line-height: 1.02;
  letter-spacing: -0.03em;
  font-weight: 600;
}
.h-section{
  font-size: clamp(32px, 4.6vw, 56px);
  line-height: 1.08;
  letter-spacing: -0.028em;
  font-weight: 600;
}
.h-sub{
  font-size: clamp(26px, 3.2vw, 40px);
  line-height: 1.15;
  letter-spacing: -0.02em;
  font-weight: 600;
}
.lede{
  color: var(--muted-2);
  font-size: clamp(16px, 1.4vw, 18px);
  line-height: 1.55;
}
.kicker-bold{
  color: var(--ink);
  font-weight: 600;
}
.script{
  font-family: var(--f-script);
  font-weight: 400;
  color: var(--muted-2);
  font-size: 22px;
  letter-spacing:0;
}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  height:48px;
  padding: 0 22px;
  border-radius: var(--r-pill);
  font-weight: 500;
  font-size: 15px;
  transition: transform .15s ease, background .2s ease, color .2s ease, box-shadow .2s ease;
  white-space: nowrap;
}
.btn-dark{
  background: var(--black);
  color: #fff;
}
.btn-dark:hover{background:#000;transform: translateY(-1px)}
.btn-sm{height:40px;padding:0 18px;font-size:14px}
.btn-lg{height:56px;padding:0 28px;font-size:16px}

/* Checks */
.checks{
  display:flex;flex-direction:column;gap:10px;align-items:center;
  color: var(--accent);
  font-weight: 500;
  font-size: 16px;
}
.checks span{display:inline-flex;align-items:center;gap:8px}
.checks svg{width:16px;height:16px;stroke:currentColor}

/* Section spacing */
section{padding: clamp(56px, 8vw, 120px) 0}
section.tight{padding: clamp(40px, 5vw, 72px) 0}

/* Utility */
.center{text-align:center}
.muted{color:var(--muted-2)}
.divider{height:1px;background:var(--line);width:100%}
.stars{color: var(--star);font-size:22px;letter-spacing:3px;display:inline-block}

/* Cards */
.card{
  background: var(--white);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-md);
}
.card-grey{
  background: var(--card-grey);
  border-radius: var(--r-lg);
}

/* Reveal on scroll */
.reveal{opacity:0; transform: translateY(14px); transition: opacity .7s ease, transform .7s ease}
.reveal.in{opacity:1; transform: none}

/* ---------- NAV ---------- */
.nav-wrap{
  position: sticky; top: 14px; z-index: 50;
  padding: 14px var(--gutter) 0;
  display:flex;justify-content:center;
  pointer-events:none;
}
.nav{
  pointer-events:auto;
  display:flex;align-items:center;gap:28px;
  background: var(--accent);
  border-radius: var(--r-pill);
  padding: 8px 10px 8px 20px;
  box-shadow: 0 2px 10px rgba(194,26,26,.18), 0 8px 24px rgba(194,26,26,.22);
  width:min(100%, 980px);
}
.nav-logo{
  display:flex;align-items:center;gap:10px;
  font-weight:700;font-size:18px;letter-spacing:-.015em;
  white-space:nowrap;flex-shrink:0;
  color: var(--accent);
  text-decoration:none;
}
.nav-logo svg{width:26px;height:26px}
.nav-logo .brand-mark{
  width:28px;height:28px;display:block;flex-shrink:0;
  image-rendering:-webkit-optimize-contrast;
}
/* Nav pill (red): wordmark flips to black, scissors flip to white */
.nav-wrap .nav-logo{color: #000}
.footer-brand .nav-logo{color: var(--accent)}
.footer-brand .brand-mark{width:32px;height:32px}
.nav-links{display:flex;gap:22px;align-items:center;margin-left:6px}
.nav-links a{color:#fff;font-size:15px;font-weight:500;opacity:.95}
.nav-links a:hover{opacity:1}
.nav-spacer{flex:1}
.nav-right{display:flex;align-items:center;gap:6px}
.nav-right .login{padding:0 14px;font-size:15px;font-weight:500;color:#fff}
.nav-right .login:hover{color:#fff;opacity:.9}
.nav-toggle{display:none;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--r-pill)}
.nav-toggle svg{width:22px;height:22px;stroke:#fff}

@media (max-width: 860px){
  .nav{padding: 8px 8px 8px 16px}
  .nav-links{display:none}
  .nav-right .login{display:none}
  .nav-toggle{display:inline-flex}
}

.mobile-menu{
  display:none;
  position:fixed;inset:0;z-index:60;
  background: rgba(15,15,15,.55);
  backdrop-filter: blur(4px);
}
.mobile-menu.open{display:block}
.mobile-menu-inner{
  position:absolute;left:12px;right:12px;top:12px;
  background:#fff;border-radius:24px;padding:18px;
  box-shadow: var(--shadow-lg);
}
.mobile-menu-inner .close{
  position:absolute;right:14px;top:14px;width:40px;height:40px;
  display:inline-flex;align-items:center;justify-content:center;border-radius:999px;
}
.mobile-menu-inner a{display:block;padding:14px 8px;border-bottom:1px solid var(--line);font-weight:500;font-size:17px}
.mobile-menu-inner a:last-of-type{border-bottom:0}
.mobile-menu-inner .mm-cta{margin-top:14px;display:flex;gap:10px}
.mobile-menu-inner .mm-cta .btn{flex:1}

/* ---------- HERO ---------- */
.hero{
  position:relative;
  padding: clamp(90px, 11vw, 150px) 0 0;
  overflow:hidden;
}
.hero-inner{position:relative; z-index:3; text-align:center; max-width: 920px; margin: 0 auto}
.hero h1{margin-top: 22px}
.hero .lede{margin: 22px auto 34px; max-width: 620px}
.hero .cta-row{display:flex;justify-content:center; margin-bottom: 34px}

.hero-deco{
  position:absolute; inset:0; pointer-events:none; z-index:1;
  overflow:hidden;
}
.hero-deco .prop{
  position:absolute;
  filter: drop-shadow(0 18px 28px rgba(0,0,0,.10));
  opacity: .95;
  user-select:none;
}
/* Laptop — top right, large */
.hero-deco .prop-laptop{
  right: -3vw; top: 40px;
  width: min(28vw, 360px);
  transform: rotate(-4deg);
}
/* Keyboard — bottom left, angled */
.hero-deco .prop-keyboard{
  left: -4vw; bottom: 60px;
  width: min(32vw, 400px);
  transform: rotate(-6deg);
}
/* Pencil — upper left, diagonal */
.hero-deco .prop-pencil{
  left: 3vw; top: 90px;
  width: min(18vw, 220px);
  transform: rotate(28deg);
}
/* Invoice stack — lower right */
.hero-deco .prop-invoice{
  right: 5vw; bottom: 40px;
  width: min(16vw, 200px);
  transform: rotate(8deg);
}

@media (max-width: 1180px){
  .hero-deco .prop-pencil{width: 150px; left: 1vw; top: 60px}
  .hero-deco .prop-invoice{width: 150px; right: 2vw; bottom: 20px}
}
@media (max-width: 860px){
  .hero-deco .prop{opacity:.35}
  .hero-deco .prop-laptop{width: 200px; top: 10px; right: -5vw}
  .hero-deco .prop-keyboard{width: 220px; bottom: 10px; left: -6vw}
  .hero-deco .prop-pencil{display:none}
  .hero-deco .prop-invoice{display:none}
}

/* Invoice card (overlapping hero) */
.invoice-stage{
  position:relative;
  margin: clamp(40px,6vw,80px) auto 0;
  max-width: 960px;
  padding: 0 var(--gutter);
}
.invoice-card{
  background:#fff; border-radius: 22px; box-shadow: var(--shadow-lg);
  padding: 28px clamp(20px,3vw,40px);
  position:relative; z-index: 2;
}
.invoice-behind{
  position:absolute; left: -28px; top: 30px; width: 78%; height: 92%;
  background:#fff; border-radius: 22px; box-shadow: var(--shadow-md);
  transform: rotate(-3.2deg);
  z-index:1;
  opacity:.9;
}
.invoice-top{display:flex;gap:40px;align-items:flex-start;padding-bottom:18px;border-bottom:1px solid var(--line)}
.invoice-top .label{font-size:11px;letter-spacing:.14em;color:var(--muted);text-transform:uppercase}
.invoice-top .num{font-size:28px;font-weight:600;margin-top:4px}
.inv-grid{display:grid;grid-template-columns: 1fr 1fr; gap: 40px; padding: 22px 0 0}
.inv-party .party-head{display:flex;align-items:center;gap:12px;margin-top:8px}
.inv-party .party-head .logo{width:36px;height:36px;border-radius:999px;flex:none}
.inv-party .party-head b{font-size:22px;font-weight:600}
.inv-party .email{color:var(--muted-2);font-size:14px;margin-top:4px}
.inv-amount{
  margin-top:22px;padding:16px 0;border-top:1px solid var(--line);
  display:grid;grid-template-columns:1fr 1fr;gap:10px;align-items:end
}
.inv-amount .big{font-size:28px;font-weight:600}
.inv-amount .sub{font-size:12px;letter-spacing:.12em;color:var(--muted);text-transform:uppercase}
.inv-amount .due{color:var(--muted-2);font-size:14px;text-align:right}
.inv-line{
  margin-top:14px; display:grid;
  grid-template-columns: 2fr .5fr .8fr 1fr;
  gap:10px;
  padding-top:14px; border-top:1px solid var(--line);
  font-size:12px; letter-spacing:.12em; color:var(--muted); text-transform:uppercase
}
.inv-line-row{
  display:grid;grid-template-columns: 2fr .5fr .8fr 1fr;gap:10px;
  padding-top:10px; font-size:15px; color:var(--ink)
}

@media (max-width: 640px){
  .inv-grid{grid-template-columns: 1fr; gap: 18px}
  .invoice-behind{display:none}
  .inv-line, .inv-line-row{grid-template-columns: 2fr 1fr}
  .inv-line :nth-child(2),
  .inv-line :nth-child(3),
  .inv-line-row :nth-child(2),
  .inv-line-row :nth-child(3){display:none}
}

/* ---------- Logo marquee ---------- */
.logo-strip{padding: clamp(72px, 8vw, 110px) 0 clamp(40px, 6vw, 80px)}
.logo-strip .label{color:var(--muted-2);text-align:center;font-size:15px;margin-bottom:26px}
.marquee{
  overflow:hidden; -webkit-mask-image: linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent);
          mask-image: linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent);
}
.marquee-track{
  display:flex;gap:64px;animation: slide 38s linear infinite;width:max-content;
  align-items:center;
}
.marquee-track span{
  color: #8E8E8E; font-weight: 600; letter-spacing:.06em; font-size:18px;
  opacity:.85; white-space:nowrap;
}
@keyframes slide{
  from{transform: translateX(0)}
  to{transform: translateX(-50%)}
}

/* ---------- Testimonial pull-quote ---------- */
.pullquote{padding: clamp(40px,6vw,80px) 0}
.pullquote .inner{
  max-width: 980px; margin: 0 auto;
  background: var(--page-alt);
  border-radius: var(--r-xl);
  padding: clamp(40px,5vw,72px) clamp(24px,4vw,60px);
  text-align:center;
}
.pullquote .stars{margin-bottom:18px}
.pullquote blockquote{
  margin: 0 auto; max-width: 780px;
  font-size: clamp(22px, 2.4vw, 30px);
  line-height: 1.28; font-weight: 500; letter-spacing: -0.015em;
}
.pullquote .attr{margin-top:16px}

/* ---------- Features grid ---------- */
.section-head{display:grid;grid-template-columns: 1.1fr 1fr; gap: 40px; align-items:end; margin-bottom: 48px}
.section-head h2{max-width: 640px}
.section-head p{max-width: 460px}
@media (max-width: 820px){
  .section-head{grid-template-columns: 1fr; gap: 18px}
}

.grid-6{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
@media (max-width: 900px){ .grid-6{grid-template-columns: repeat(2, 1fr)} }
@media (max-width: 560px){ .grid-6{grid-template-columns: 1fr} }

.feat{
  background: var(--card-grey);
  border-radius: var(--r-lg);
  padding: 22px;
  display:flex; flex-direction:column; gap:22px;
  min-height: 180px;
}
.feat .ic{display:flex;align-items:center}
.feat .icon-tile{
  width:44px;height:44px;border-radius:12px;
  background: var(--accent-soft);
  color: var(--accent-ink);
  display:inline-flex;align-items:center;justify-content:center;
  box-shadow: 0 1px 2px rgba(194,26,26,.08);
}
.feat .icon-tile svg{width:22px;height:22px}
.feat .title{font-weight:600;font-size:17px;line-height:1.35;max-width:22ch}

/* ---------- Problem tiles ---------- */
.problem-cols{
  display:grid; grid-template-columns: repeat(3, 1fr); gap:28px; margin-top: 36px;
}
@media (max-width: 820px){ .problem-cols{grid-template-columns: 1fr} }
.prob .tag{font-weight:600;font-size:17px;margin-bottom:8px}
.prob-blue .tag{color: var(--blue)}
.prob-pink .tag{color: var(--pink)}
.prob-lav .tag{color: var(--lav)}
.prob .lede b{color:var(--ink);font-weight:600}

.prob-tiles{
  display:grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 36px;
}
@media (max-width: 820px){ .prob-tiles{grid-template-columns: 1fr} }
.prob-tile{
  border-radius: var(--r-lg);
  min-height: 220px;
  padding: 30px;
  display:flex; align-items:center; justify-content:center;
}
.prob-tile.blue{background: var(--blue-bg)}
.prob-tile.pink{background: var(--pink-bg)}
.prob-tile.lav{background: var(--lav-bg)}
.prob-tile svg{width:56%;max-width:240px;height:auto}

/* ---------- Feature block (image-led) ---------- */
.feature-block{padding: clamp(50px,6vw,90px) 0}
.feature-block .head{
  display:grid;grid-template-columns: 1.1fr 1fr; gap: 40px; align-items:end; margin-bottom: 44px;
}
@media (max-width: 820px){ .feature-block .head{grid-template-columns: 1fr; gap: 14px} }
.feature-block .head h2{max-width: 640px}
.feature-block .head p{max-width: 480px}

.photo-frame{
  position:relative; border-radius: var(--r-xl); overflow:hidden;
  box-shadow: var(--shadow-md);
  background: #ECE9E1;
  aspect-ratio: 16/9;
}
.photo-frame.tall{aspect-ratio: 4/3}
.photo-frame .placeholder-label{
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  color: rgba(255,255,255,.25); font-size:11px; letter-spacing:.14em; text-transform:uppercase;
  pointer-events:none;
}
.photo-frame .inner{
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  padding: 8%;
}
.inline-testimonial{
  text-align:left; margin-top: 30px;
}
.inline-testimonial blockquote{
  max-width: 440px; margin: 10px 0 0;
  font-size: 16px; font-weight:500; line-height:1.45;
}
.inline-testimonial .attr{margin-top: 8px; font-size: 18px}
.inline-testimonial .stars{font-size:18px;letter-spacing:2px}

.inline-fact{
  text-align:left; margin-top: 30px; max-width: 520px;
  border-left: 2px solid #111; padding-left: 18px;
}
.inline-fact .fact-label{
  font-size: 12px; letter-spacing: 1.5px; font-weight: 700;
  text-transform: uppercase; color:#111;
}
.inline-fact .fact-body{
  margin-top: 8px; font-size: 16px; font-weight: 500; line-height: 1.5;
  color: var(--muted-2);
}

/* Invoice paper inside photo */
.paper{
  background:#fff; border-radius: 10px; width: min(520px, 80%);
  box-shadow: 0 14px 40px rgba(0,0,0,.25), 0 2px 4px rgba(0,0,0,.15);
  padding: 22px 24px; font-size: 13px;
  transform: rotate(-1deg);
}
.paper .top{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.paper .top .n{font-size:18px;font-weight:600}
.paper .top .label{font-size:10px;letter-spacing:.14em;color:var(--muted);text-transform:uppercase}
.paper .row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:16px}
.paper .row b{display:block;font-size:14px}
.paper .row .e{color:var(--muted-2);font-size:12px}
.paper table{width:100%;border-collapse:collapse;font-size:12px}
.paper th{font-size:10px;letter-spacing:.14em;color:var(--muted);text-transform:uppercase;text-align:left;padding:8px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);font-weight:500}
.paper td{padding:10px 0;border-bottom:1px solid var(--line)}

/* Payment method card mock */
.pm-card{
  background:#fff;border-radius:20px;box-shadow:var(--shadow-lg);
  width:min(520px, 92%); padding: 22px;
}
.pm-card .lbl{font-size:11px;letter-spacing:.14em;color:var(--muted);text-transform:uppercase;margin-bottom:12px}
.pm-methods{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:14px}
.pm-methods .tile{
  border:1.5px solid var(--line); border-radius: 12px; padding: 14px 10px;
  display:flex;flex-direction:column;align-items:center;gap:8px;
  font-size:13px; font-weight:500;
}
.pm-methods .tile.sel{border-color: var(--ink)}
.pm-methods .tile svg{width:22px;height:22px}
.pm-row{display:grid;grid-template-columns: 1fr 1fr;gap:10px;margin-bottom:14px}
.pm-drop{
  border:1.5px solid var(--line); border-radius: 12px; padding: 10px 12px;
  display:flex;justify-content:space-between;align-items:center;font-size:14px
}
.pm-card .btn{width:100%}

/* Phone with notifications */
.phone{
  width: min(320px, 60%); aspect-ratio: 9/19;
  background:#111; border-radius: 36px; padding: 14px; box-shadow: 0 30px 70px rgba(0,0,0,.35);
  position:relative;
}
.phone .screen{
  background: #2b1a16;
  background-image: linear-gradient(180deg, rgba(40,20,15,.4), rgba(20,10,8,.6));
  height:100%; border-radius: 26px; padding: 40px 10px 14px; display:flex;flex-direction:column; gap:10px;
}
.notif{
  background: rgba(255,255,255,.82);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-radius: 14px;
  padding: 10px 12px;
  display:grid;grid-template-columns: 32px 1fr auto;gap:10px;align-items:center;
  font-size: 12px;
  color: #111;
}
.notif .ic{width:32px;height:32px;border-radius:8px;background:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700}
.notif .title{font-weight:600}
.notif .sub{color:#222;opacity:.75;font-size:11px;margin-top:1px}
.notif .time{font-size:11px;color:#333;opacity:.6}

/* Recurring invoice + email reminder mocks */
.mock-pair{display:grid;grid-template-columns:1fr 1fr;gap:24px;width:92%}
@media (max-width: 820px){ .mock-pair{grid-template-columns: 1fr} }
.mock-window{
  background:#fff;border-radius:14px;box-shadow: var(--shadow-lg);
  overflow:hidden;
  transform: rotate(-1deg);
}
.mock-window .bar{background:#F3F2EE;padding:8px 12px;display:flex;gap:6px;align-items:center}
.mock-window .bar .dot{width:10px;height:10px;border-radius:50%}
.mock-window .bar .red{background:#FF5F56}
.mock-window .bar .yel{background:#FFBD2E}
.mock-window .bar .grn{background:#27C93F}
.mock-window .bar .title{font-size:11px;color:var(--muted);margin-left:10px}
.mock-window .body{padding:16px;font-size:12px}
.mock-window .line{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--line)}

/* Integrations */
.integrations{
  background: var(--page-alt);
  border-radius: var(--r-xl);
  padding: clamp(30px,5vw,60px);
}
.integrations .head{max-width: 720px}
.int-rows{display:grid;grid-template-columns: 1fr; gap: 12px; margin-top: 26px}
.int-row{
  display:flex;align-items:center;gap:16px;
  background:#fff;border-radius:14px;padding:16px 18px;box-shadow:var(--shadow-sm);
}
.int-row .logo{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:13px;flex:none}
.int-row b{font-weight:600}
.int-row .desc{color:var(--muted-2);font-size:14px}

/* Closing CTA */
.closing{text-align:center}
.closing h2{margin-bottom: 16px}
.closing p{max-width: 560px; margin: 0 auto 28px}
.grass{
  margin-top: clamp(30px, 5vw, 64px);
  aspect-ratio: 16/8;
  border-radius: var(--r-xl);
  overflow:hidden;
  background: linear-gradient(180deg, #8bb25a 0%, #4f7e2a 55%, #3d6a20 100%);
  position:relative;
}
.grass::after{
  content:'';position:absolute;inset:0;
  background-image:
    radial-gradient(circle at 12% 30%, #e74c3c 0 6px, transparent 7px),
    radial-gradient(circle at 72% 40%, #f1c40f 0 4px, transparent 5px),
    radial-gradient(circle at 22% 72%, #ffffff 0 4px, transparent 5px),
    radial-gradient(circle at 84% 68%, #9b59b6 0 4px, transparent 5px),
    radial-gradient(circle at 58% 20%, #e74c3c 0 4px, transparent 5px),
    radial-gradient(circle at 35% 55%, #f1c40f 0 4px, transparent 5px);
  opacity:.8; pointer-events:none;
}
.grass .paper{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) rotate(-1deg); width:min(560px,70%)}

/* ---------- FAQ ---------- */
.faq h2{text-align:center; margin-bottom: 36px}
.faq-list{max-width: 820px; margin: 0 auto; border-top: 1px solid var(--line)}
.faq-item{border-bottom: 1px solid var(--line)}
.faq-q{
  width:100%; display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding: 22px 0; text-align:left; font-size: 17px; font-weight: 600; letter-spacing:-.005em;
}
.faq-q .plus{
  width:32px;height:32px;border-radius:999px;background:#EFEFEA;
  display:inline-flex;align-items:center;justify-content:center;flex:none;transition: transform .3s ease, background .3s ease;
}
.faq-item.open .faq-q .plus{transform: rotate(45deg); background:#111; color:#fff}
.faq-a{
  max-height:0;overflow:hidden;transition: max-height .4s ease, padding .3s ease;
  color: var(--muted-2); font-size: 15.5px; line-height: 1.6;
}
.faq-item.open .faq-a{max-height: 500px; padding: 0 0 22px}

/* ---------- Footer ---------- */
footer{background: var(--footer-bg); padding: clamp(60px, 8vw, 110px) 0 60px}
.footer-grid{
  display:grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 40px;
}
@media (max-width: 900px){ .footer-grid{grid-template-columns: 1fr 1fr} }
@media (max-width: 560px){ .footer-grid{grid-template-columns: 1fr} }
.footer-brand .tagline{
  font-size: clamp(22px, 2.6vw, 30px); font-weight: 600; letter-spacing:-.02em;
  line-height:1.15; max-width: 320px; margin: 16px 0 22px;
}
.footer-brand .withlove{margin-top:14px; display:flex;align-items:center;gap:6px}
.footer-col h4{font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:600;margin:0 0 16px}
.footer-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.footer-col a{font-size:15px;color:var(--ink-2)}
.footer-col a:hover{text-decoration: underline}

/* Footer decoration cards */
.footer-decks{
  margin-top: clamp(40px,6vw,80px);
  display:grid;grid-template-columns: repeat(3, 1fr); gap: 18px;
}
@media (max-width: 820px){ .footer-decks{grid-template-columns: 1fr} }
.footer-decks .mini{
  background:#fff;border-radius: 18px; box-shadow: var(--shadow-md);
  padding: 20px; font-size: 13px;
}
.footer-decks .mini .top{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.footer-decks .mini .top .n{font-weight:600;font-size:16px}
.footer-decks .mini .pair{display:grid;grid-template-columns: 1fr 1fr; gap:10px; margin-bottom:12px}
.footer-decks .mini .big{font-size:22px;font-weight:600}
.footer-decks .mini .btn{width:100%;height:40px;font-size:13px;margin-top:8px}

/* Stub pages */
.stub-page{min-height: 60vh; padding-top: clamp(60px, 10vw, 120px)}
.stub-page h1{margin-bottom:14px}
.stub-page p{color:var(--muted-2); max-width: 640px; font-size:17px}

/* Pricing */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:40px}
@media (max-width: 820px){ .price-grid{grid-template-columns:1fr} }
.price-card{background:var(--card-grey);border-radius:var(--r-lg);padding:28px}
.price-card.dark{background:#111;color:#fff}
.price-card.dark h3,.price-card.dark .price,.price-card.dark li{color:#fff}
.price-card.dark .price-sub{color:#aaa}
.price-card.dark .price small{color:#aaa}
.price-card h3{font-size:22px;margin-bottom:6px}
.price-sub{color:var(--muted-2);font-size:14px;margin-bottom:20px}
.price{font-size:48px;font-weight:600;letter-spacing:-.02em;margin-bottom:20px}
.price small{font-size:14px;font-weight:500;color:var(--muted-2)}
.price-card ul{list-style:none;margin:18px 0 22px;padding:0;display:flex;flex-direction:column;gap:10px;font-size:15px}
.price-card li{display:flex;gap:10px;align-items:flex-start}
.price-card li::before{content:'✓';color:var(--accent)}
.price-card.dark li::before{color:#8be3ff}
