@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&family=Playfair+Display:ital,wght@0,700;1,700&display=swap');

:root {
  --forest: #102d25;
  --green: #174b3b;
  --green-2: #236b53;
  --cream: #f6f0e4;
  --paper: #fcfaf5;
  --white: #fff;
  --ink: #17231f;
  --muted: #64716b;
  --gold: #d9ad54;
  --gold-soft: #f4e6bd;
  --line: #ddd5c6;
  --red: #8a463f;
  --shadow: 0 30px 80px rgba(16,45,37,.14);
  --serif: "Playfair Display", Georgia, serif;
  --sans: "DM Sans", ui-sans-serif, system-ui, sans-serif;
  --max: 1180px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; overflow-x: hidden; background: var(--paper); color: var(--ink); font-family: var(--sans); font-size: 17px; line-height: 1.65; }
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; }
button, a { -webkit-tap-highlight-color: transparent; }
:focus-visible { outline: 3px solid var(--gold); outline-offset: 4px; }
.skip-link { position: fixed; top: -100px; left: 16px; z-index: 100; padding: 10px 14px; background: #fff; }
.skip-link:focus { top: 16px; }
.announcement { min-height: 38px; padding: 8px max(20px, calc((100vw - var(--max)) / 2)); display: flex; justify-content: center; gap: 24px; background: var(--forest); color: #e8f1ec; font-size: 12px; letter-spacing: .02em; text-align: center; }
.announcement p { margin: 0; }
.announcement a { color: #f7d994; font-weight: 700; text-underline-offset: 3px; }
.site-header { position: sticky; top: 0; z-index: 30; min-height: 72px; padding: 10px max(20px, calc((100vw - var(--max)) / 2)); display: flex; align-items: center; justify-content: space-between; gap: 24px; border-bottom: 1px solid rgba(221,213,198,.85); background: rgba(252,250,245,.92); backdrop-filter: blur(18px); }
.brand { display: flex; align-items: center; gap: 11px; color: var(--forest); text-decoration: none; }
.brand-mark { width: 42px; height: 42px; display: grid; place-items: center; flex: 0 0 auto; border: 2px solid var(--gold); border-radius: 50%; background: var(--green); color: #fff5d9; font-size: 10px; font-weight: 700; letter-spacing: .08em; }
.brand-copy { display: grid; line-height: 1.2; }
.brand-copy strong { font-size: 14px; }
.brand-copy small { color: var(--muted); font-size: 10px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; }
.site-header nav { display: flex; align-items: center; gap: 23px; }
.site-header nav > a:not(.button) { color: var(--muted); font-size: 13px; font-weight: 700; text-decoration: none; }
.button { min-height: 52px; padding: 14px 22px; display: inline-flex; align-items: center; justify-content: center; border: 1px solid var(--green); border-radius: 4px; background: var(--green); color: #fff; font-weight: 700; line-height: 1.25; text-align: center; text-decoration: none; box-shadow: 0 14px 34px rgba(23,75,59,.2); transition: transform .2s ease, box-shadow .2s ease, background .2s ease; }
.button:hover { transform: translateY(-2px); background: var(--forest); box-shadow: 0 18px 42px rgba(23,75,59,.27); }
.button-small { min-height: 42px; padding: 10px 15px; font-size: 13px; box-shadow: none; }
.button-large { min-height: 58px; padding: 17px 25px; }
.button-gold { border-color: var(--gold); background: var(--gold); color: var(--forest); }
.button-gold:hover { background: #e5bd6a; }
.underlink { color: var(--green); font-weight: 700; text-underline-offset: 5px; }
.hero { min-height: calc(100vh - 110px); padding: 70px max(20px, calc((100vw - var(--max)) / 2)) 80px; display: grid; grid-template-columns: 1.02fr .98fr; align-items: center; gap: 56px; overflow: hidden; background: radial-gradient(circle at 82% 12%, rgba(217,173,84,.2), transparent 25rem), linear-gradient(145deg, rgba(23,75,59,.07), transparent 48%); border-bottom: 1px solid var(--line); }
.eyebrow { margin: 0 0 15px; color: var(--green-2); font-size: 11px; font-weight: 700; letter-spacing: .16em; text-transform: uppercase; }
h1, h2, h3, p, blockquote { margin-top: 0; }
h1, h2 { font-family: var(--serif); letter-spacing: -.025em; }
h1 { max-width: 720px; margin-bottom: 24px; font-size: clamp(48px, 6.5vw, 80px); line-height: 1.02; }
h2 { margin-bottom: 20px; font-size: clamp(37px, 5vw, 61px); line-height: 1.08; }
h3 { margin-bottom: 10px; font-size: 22px; line-height: 1.16; }
p:last-child { margin-bottom: 0; }
.hero-lede { max-width: 680px; margin-bottom: 27px; color: #3e4d46; font-size: clamp(19px, 2vw, 23px); }
.hero-actions { display: flex; flex-wrap: wrap; align-items: center; gap: 18px; margin-bottom: 29px; }
.proof-line { display: flex; flex-wrap: wrap; gap: 8px 22px; padding: 20px 0 0; margin: 0; border-top: 1px solid var(--line); color: var(--muted); font-size: 12px; font-weight: 700; list-style: none; }
.proof-line li::before { content: "✓"; margin-right: 7px; color: var(--green); }
.hero-art { position: relative; }
.hero-art figure { position: relative; z-index: 2; margin: 0; transform: rotate(1.5deg); border: 1px solid #e1d8c8; border-radius: 8px; background: #f2ecdf; box-shadow: var(--shadow); }
.hero-art img { border-radius: 8px 8px 0 0; }
.hero-art figcaption { padding: 14px 18px; display: flex; justify-content: space-between; gap: 14px; color: var(--muted); font-size: 10px; letter-spacing: .07em; text-transform: uppercase; }
.hero-art figcaption strong { color: var(--green); }
.floating-note { position: absolute; right: -24px; bottom: -32px; z-index: 3; width: 210px; padding: 17px; display: flex; gap: 12px; border: 1px solid var(--line); background: var(--white); box-shadow: 0 18px 45px rgba(16,45,37,.15); }
.floating-note span { color: var(--gold); font-family: var(--serif); font-size: 30px; font-weight: 700; line-height: 1; }
.floating-note p { margin: 0; color: var(--muted); font-size: 12px; line-height: 1.4; }
.floating-note strong { color: var(--green); }
.art-orbit { position: absolute; border: 1px solid rgba(23,75,59,.16); border-radius: 50%; }
.art-orbit-one { width: 500px; height: 500px; top: -80px; right: -100px; }
.art-orbit-two { width: 350px; height: 350px; left: -60px; bottom: -80px; }
.section-pad { padding: 106px max(20px, calc((100vw - var(--max)) / 2)); }
.recognition { display: grid; grid-template-columns: .9fr 1.1fr; gap: 90px; background: #fff; }
.recognition-lead { position: sticky; top: 130px; align-self: start; }
.recognition-body { color: #405048; font-size: 19px; }
.question-list { padding: 0; margin: 30px 0; border-top: 1px solid var(--line); list-style: none; }
.question-list li { padding: 17px 4px; border-bottom: 1px solid var(--line); color: var(--forest); font-weight: 700; }
.question-list li::before { content: "→"; margin-right: 12px; color: var(--gold); }
.tagalog-line { color: var(--green) !important; font-family: var(--serif); font-size: 28px; font-style: italic; font-weight: 700; }
.truth-band { padding: 72px max(20px, calc((100vw - var(--max)) / 2)); background: var(--forest); color: #fff; }
.truth-card { max-width: 980px; margin: 0 auto; text-align: center; }
.truth-band .eyebrow { color: #e4c77e; }
.truth-card blockquote { margin: 20px 0 26px; color: #fff2ce; font-family: var(--serif); font-size: clamp(36px, 5vw, 62px); font-weight: 700; line-height: 1.13; }
.truth-card > p:last-child { max-width: 750px; margin-inline: auto; color: #cbd9d3; font-size: 18px; }
.section-heading { max-width: 830px; margin-bottom: 46px; }
.section-heading > p:last-child { color: var(--muted); font-size: 19px; }
.method-grid { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.method-card { min-height: 295px; padding: 28px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); background: #fff; }
.method-card span { margin-bottom: 50px; display: block; color: var(--gold); font-family: var(--serif); font-size: 42px; font-weight: 700; }
.method-card p { color: var(--muted); font-size: 14px; }
.outcome { display: grid; grid-template-columns: .85fr 1.15fr; align-items: center; gap: 80px; background: var(--cream); border-block: 1px solid var(--line); }
.outcome-copy > p:not(.eyebrow) { color: var(--muted); font-size: 18px; }
.plan-card { overflow: hidden; border: 1px solid #d2c6b2; background: #fff; box-shadow: var(--shadow); }
.plan-top { padding: 22px 25px; display: flex; justify-content: space-between; gap: 15px; background: var(--green); color: #fff; font-size: 12px; text-transform: uppercase; }
.plan-top strong { color: #f3d998; }
.plan-card ul { padding: 0 25px; margin: 0; list-style: none; }
.plan-card li { padding: 18px 2px; display: grid; grid-template-columns: 38px 1fr; gap: 12px; border-bottom: 1px solid var(--line); color: #3f4f47; font-size: 14px; font-weight: 600; }
.plan-card li:last-child { border-bottom: 0; }
.plan-card li span { color: var(--gold); font-family: var(--serif); font-size: 17px; }
.inside { background: #fff; }
.product-feature { margin-bottom: 20px; padding: 38px; display: grid; grid-template-columns: 230px 1fr; gap: 48px; align-items: center; background: var(--forest); color: #fff; }
.product-feature img, .product-card img { border: 1px solid rgba(255,255,255,.3); box-shadow: 0 15px 35px rgba(16,45,37,.22); }
.product-feature h3 { margin: 12px 0 18px; font-family: var(--serif); font-size: clamp(32px, 4vw, 50px); }
.product-feature p { color: #ccdad4; }
.pill { padding: 6px 9px; background: rgba(217,173,84,.18); color: #f3d68f; font-size: 10px; font-weight: 700; letter-spacing: .13em; text-transform: uppercase; }
.clean-list { padding: 0; margin: 25px 0 0; display: flex; flex-wrap: wrap; gap: 10px; list-style: none; }
.clean-list li { padding: 7px 10px; border: 1px solid rgba(255,255,255,.18); color: #e9f1ed; font-size: 11px; font-weight: 600; }
.product-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
.product-card { min-height: 280px; padding: 25px; display: grid; grid-template-columns: 130px 1fr; gap: 25px; align-items: start; border: 1px solid var(--line); background: var(--paper); }
.product-card span { color: var(--green-2); font-size: 10px; font-weight: 700; letter-spacing: .13em; text-transform: uppercase; }
.product-card h3 { margin-top: 7px; }
.product-card p { color: var(--muted); font-size: 14px; }
.founder { display: grid; grid-template-columns: .45fr 1fr; gap: 70px; background: var(--cream); border-block: 1px solid var(--line); }
.founder-number { display: grid; place-items: start center; color: var(--gold); font-family: var(--serif); font-size: clamp(180px, 25vw, 360px); font-weight: 700; line-height: .65; opacity: .75; }
.founder-story { max-width: 730px; color: #405048; font-size: 18px; }
.founder-story h2 { color: var(--ink); }
.founder-signoff { margin-top: 34px; display: grid; color: var(--forest); }
.founder-signoff span { color: var(--muted); font-size: 12px; }
.fit { background: #fff; }
.fit-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.fit-card { padding: 34px; border: 1px solid var(--line); }
.fit-card h3 { font-family: var(--serif); font-size: 30px; }
.fit-card ul { padding: 0; margin: 25px 0 0; list-style: none; }
.fit-card li { position: relative; padding: 14px 0 14px 30px; border-bottom: 1px solid var(--line); color: #47574f; font-size: 14px; }
.fit-card li:last-child { border: 0; }
.fit-card li::before { position: absolute; left: 2px; font-weight: 700; }
.fit-yes { background: #edf4f0; }.fit-yes li::before { content: "✓"; color: var(--green); }
.fit-no { background: #f7efeb; }.fit-no li::before { content: "×"; color: var(--red); font-size: 20px; line-height: 1; }
.offer { background: linear-gradient(180deg, var(--cream), var(--paper)); }
.offer-card { overflow: hidden; display: grid; grid-template-columns: .9fr 1.1fr; border-top: 7px solid var(--gold); background: #fff; box-shadow: var(--shadow); }
.offer-visual { display: grid; place-items: center; padding: 35px; background: #e9e2d4; }
.offer-visual img { border: 1px solid #d8cdb9; box-shadow: 0 22px 50px rgba(16,45,37,.16); }
.offer-copy { padding: clamp(34px, 5vw, 65px); }
.offer-copy h2 { font-size: clamp(40px, 5vw, 58px); }
.offer-copy > p:not(.eyebrow,.secure-note,.legal-note) { color: var(--muted); }
.offer-list { padding: 18px 0; margin: 25px 0; border-block: 1px solid var(--line); list-style: none; }
.offer-list li { padding: 7px 0; color: #3d4d45; font-size: 14px; font-weight: 600; }
.offer-list li::before { content: "✓"; margin-right: 9px; color: var(--green); }
.price-row { margin: 25px 0; display: flex; align-items: end; gap: 12px; }
.price-row p { margin: 0; color: var(--forest); line-height: 1; }
.price-row span { margin-right: 7px; font-size: 12px; font-weight: 700; letter-spacing: .1em; }
.price-row strong { font-family: var(--serif); font-size: 68px; }
.price-row small, .secure-note { color: var(--muted); font-size: 11px; }
.secure-note { margin: 12px 0 0; }
.legal-note { margin: 25px 0 0; padding: 13px; background: var(--cream); color: #6d5c3b !important; font-size: 10px; }
.faq-list { max-width: 920px; display: grid; gap: 11px; }
.faq-list details { border: 1px solid var(--line); background: #fff; }
.faq-list summary { position: relative; padding: 21px 54px 21px 22px; cursor: pointer; color: var(--forest); font-weight: 700; list-style: none; }
.faq-list summary::-webkit-details-marker { display: none; }
.faq-list summary::after { content: "+"; position: absolute; top: 12px; right: 21px; color: var(--gold); font-family: var(--serif); font-size: 30px; }
.faq-list details[open] summary::after { content: "−"; }
.faq-list details p { padding: 0 22px 22px; margin: 0; color: var(--muted); font-size: 14px; }
.closing { background: var(--forest); color: #fff; text-align: center; }
.closing-copy { max-width: 850px; margin: 0 auto; }
.closing .eyebrow { color: #ebca7c; }
.closing h2 { color: #fff1cb; font-size: clamp(48px, 8vw, 85px); }
.closing-copy > p:not(.eyebrow,.closing-tagalog) { max-width: 700px; margin-inline: auto; color: #cbd8d2; font-size: 18px; }
.closing .button { margin-top: 22px; }
.closing-tagalog { margin-top: 24px !important; color: #f0d99f; font-family: var(--serif); font-style: italic; }
footer { padding: 30px max(20px, calc((100vw - var(--max)) / 2)); display: flex; justify-content: space-between; gap: 30px; background: #0b211b; color: #b8c8c1; font-size: 11px; }
footer p { margin: 3px 0 0; }
footer nav { display: flex; flex-wrap: wrap; align-items: center; gap: 18px; }
footer a, footer button { border: 0; padding: 0; background: transparent; color: #d5e1dc; font: inherit; text-decoration: underline; text-underline-offset: 3px; cursor: pointer; }
.mobile-buy { display: none; }
.cookie-banner { position: fixed; right: 18px; bottom: 18px; z-index: 50; width: min(620px, calc(100% - 36px)); padding: 17px; display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 18px; border: 1px solid var(--line); background: #fff; box-shadow: var(--shadow); }
.cookie-banner[hidden] { display: none; }
.cookie-banner p { margin: 3px 0 0; color: var(--muted); font-size: 11px; }
.cookie-actions { display: flex; gap: 8px; }
.button-quiet { background: transparent; color: var(--green); box-shadow: none; }
.legal-main { min-height: calc(100vh - 170px); padding: 80px max(20px, calc((100vw - 860px) / 2)); }
.legal-content h1 { margin-bottom: 28px; font-family: var(--serif); font-size: clamp(44px, 7vw, 70px); line-height: 1.05; }
.legal-content h2 { margin-top: 42px; font-family: var(--serif); font-size: 29px; }
.legal-content p { color: #405048; }
.reveal { opacity: 0; transform: translateY(18px); transition: opacity .65s ease, transform .65s ease; }
.reveal.is-visible { opacity: 1; transform: none; }

@media (max-width: 1000px) {
  .hero, .recognition, .outcome, .founder, .offer-card { grid-template-columns: 1fr; }
  .hero { min-height: auto; }
  .hero-art { max-width: 720px; margin: 10px auto 0; }
  .recognition-lead { position: static; }
  .method-grid { grid-template-columns: repeat(2, 1fr); }
  .founder-number { display: none; }
  .site-header nav > a:not(.button) { display: none; }
}

@media (max-width: 720px) {
  body { padding-bottom: 69px; font-size: 16px; }
  .announcement { display: none; }
  .site-header { min-height: 64px; }
  .brand-copy small { display: none; }
  .brand-copy strong { max-width: 140px; font-size: 11px; }
  .site-header nav .button { display: none; }
  .hero { padding-top: 48px; padding-bottom: 60px; gap: 38px; }
  h1 { font-size: 48px; }
  h2 { font-size: 38px; }
  .hero-actions { align-items: stretch; flex-direction: column; }
  .hero-actions .button { width: 100%; }
  .hero-art figcaption { display: grid; }
  .floating-note { right: -7px; bottom: -25px; width: 180px; }
  .section-pad { padding-top: 72px; padding-bottom: 72px; }
  .method-grid, .product-grid, .fit-grid { grid-template-columns: 1fr; }
  .method-card { min-height: auto; }
  .method-card span { margin-bottom: 25px; }
  .product-feature { padding: 22px; grid-template-columns: 100px 1fr; gap: 20px; align-items: start; }
  .product-feature h3 { font-size: 27px; }
  .product-feature .clean-list { display: none; }
  .product-feature p { font-size: 13px; }
  .product-card { min-height: auto; padding: 17px; grid-template-columns: 88px 1fr; gap: 16px; }
  .product-card h3 { font-size: 18px; }
  .product-card p { font-size: 12px; }
  .offer-visual { padding: 20px; }
  .offer-copy { padding: 28px 22px; }
  footer { flex-direction: column; padding-bottom: 26px; }
  .cookie-banner { bottom: 80px; grid-template-columns: 1fr; }
  .cookie-actions .button { flex: 1; }
  .mobile-buy { position: fixed; right: 0; bottom: 0; left: 0; z-index: 40; padding: 9px 12px; display: flex; align-items: center; justify-content: space-between; gap: 12px; border-top: 1px solid #d6ccb9; background: rgba(252,250,245,.96); backdrop-filter: blur(15px); box-shadow: 0 -8px 30px rgba(16,45,37,.1); }
  .mobile-buy div { display: grid; line-height: 1.2; }
  .mobile-buy strong { color: var(--forest); font-size: 12px; }
  .mobile-buy span { color: var(--muted); font-size: 10px; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { transition-duration: .01ms !important; }
  .reveal { opacity: 1; transform: none; }
}
