/* =====================================================
   DIRTY CHAINS CTP — dca.css
   A Lazy Dog Apps joint. Vintage outdoor aesthetic.
   Off course. On purpose.  Self-hosted fonts (CSP-safe).
   ===================================================== */

/* ---------- FONTS (self-hosted, served from this origin) ---------- */
@font-face{font-family:'Alfa Slab One';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/alfa-slab-one-latin-400-normal.woff2') format('woff2');}
@font-face{font-family:'Archivo';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/archivo-latin-400-normal.woff2') format('woff2');}
@font-face{font-family:'Archivo';font-style:normal;font-weight:500;font-display:swap;src:url('/assets/fonts/archivo-latin-500-normal.woff2') format('woff2');}
@font-face{font-family:'Archivo';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/archivo-latin-600-normal.woff2') format('woff2');}
@font-face{font-family:'Archivo';font-style:normal;font-weight:700;font-display:swap;src:url('/assets/fonts/archivo-latin-700-normal.woff2') format('woff2');}
@font-face{font-family:'Kalam';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/kalam-latin-400-normal.woff2') format('woff2');}
@font-face{font-family:'Kalam';font-style:normal;font-weight:700;font-display:swap;src:url('/assets/fonts/kalam-latin-700-normal.woff2') format('woff2');}

:root{
  --bone:#EFE7D4; --bone-2:#E8DFC7; --bone-light:#F5EFDE;
  --forest:#3E4428; --forest-deep:#2A3220;
  --rust:#B85A2E; --rust-dark:#944524; --rust-light:#D97749;
  --navy:#1C2A38; --navy-deep:#131E2A;
  --tan:#A8835A; --tan-light:#C9A67E;
  --img-light:url('https://firebasestorage.googleapis.com/v0/b/dirtychainsctp.firebasestorage.app/o/outside.png?alt=media&token=9457825e-9601-468d-bf3f-25c22c49d138');
  --img-dark:url('https://firebasestorage.googleapis.com/v0/b/dirtychainsctp.firebasestorage.app/o/outside%202.png?alt=media&token=c31daa06-e112-434d-9fd8-0b8330732dfb');
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Archivo',-apple-system,system-ui,sans-serif;background:var(--bone);color:var(--forest);line-height:1.65;font-size:17px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
h1,h2,h3,h4{font-family:'Alfa Slab One',serif;font-weight:400;line-height:1.05;letter-spacing:-0.005em;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
.script{font-family:'Kalam',cursive;font-weight:700;font-style:italic;}
.accent{color:var(--rust);}
.container{max-width:1200px;margin:0 auto;}

/* ---------- NAV ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(239,231,212,0.94);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1.5px solid var(--forest);}
.nav-inner{max-width:1200px;margin:0 auto;padding:14px 32px;display:flex;align-items:center;justify-content:space-between;gap:24px;}
.nav-logo{font-family:'Alfa Slab One',serif;font-size:17px;color:var(--forest);letter-spacing:0.01em;display:flex;align-items:center;gap:10px;}
.nav-logo img{height:38px;width:auto;border-radius:8px;border:2px solid var(--forest);}
.nav-links{display:flex;gap:30px;align-items:center;list-style:none;}
.nav-links a{font-family:'Archivo',sans-serif;font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:0.14em;color:var(--forest);transition:color 0.2s;}
.nav-links a:hover,.nav-links a.active{color:var(--rust);}
.nav-links a.parent-link{opacity:0.7;}
.nav-cta{background:var(--rust);color:var(--bone)!important;padding:10px 20px;font-family:'Alfa Slab One',serif;font-size:12px;letter-spacing:0.08em;border:2px solid var(--rust);transition:all 0.2s;text-transform:uppercase;}
.nav-cta:hover{background:var(--rust-dark);border-color:var(--rust-dark);}
.nav-toggle{display:none;background:transparent;border:2px solid var(--forest);color:var(--forest);width:42px;height:42px;cursor:pointer;font-size:20px;align-items:center;justify-content:center;}

/* ---------- BUTTONS ---------- */
.btn{display:inline-block;font-family:'Alfa Slab One',serif;font-size:15px;letter-spacing:0.05em;padding:16px 28px;border:2.5px solid;transition:all 0.15s ease-out;cursor:pointer;text-align:center;text-transform:uppercase;}
.btn-primary{background:var(--rust);color:var(--bone);border-color:var(--rust);}
.btn-primary:hover{background:var(--rust-dark);border-color:var(--rust-dark);transform:translateY(-2px);box-shadow:0 4px 0 var(--forest);}
.btn-secondary{background:transparent;color:var(--forest);border-color:var(--forest);}
.btn-secondary:hover{background:var(--forest);color:var(--bone);transform:translateY(-2px);}
.btn-dark{background:transparent;color:var(--bone);border-color:var(--bone);}
.btn-dark:hover{background:var(--bone);color:var(--forest);transform:translateY(-2px);}

/* ---------- HERO ---------- */
.hero{position:relative;padding:180px 32px 120px;text-align:center;overflow:hidden;min-height:92vh;display:flex;align-items:center;justify-content:center;}
.hero::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(239,231,212,0.74) 0%,rgba(239,231,212,0.80) 40%,rgba(239,231,212,0.95) 100%),var(--img-light) center center/cover no-repeat;z-index:0;}
.hero-content{position:relative;z-index:1;max-width:900px;margin:0 auto;}
.kicker{font-family:'Kalam',cursive;font-weight:700;font-size:19px;color:var(--rust);margin-bottom:28px;letter-spacing:0.02em;}
.kicker-dashes{color:var(--forest);opacity:0.5;margin:0 10px;font-family:'Archivo',sans-serif;font-weight:400;}
.hero h1{font-size:clamp(46px,8vw,100px);color:var(--forest);margin-bottom:26px;}
.hero h1 em{font-family:'Kalam',cursive;font-style:italic;font-weight:700;color:var(--rust);letter-spacing:0;}
.hero-sub{font-family:'Kalam',cursive;font-weight:700;font-size:clamp(21px,3vw,29px);color:var(--forest-deep);margin-bottom:40px;max-width:640px;margin-left:auto;margin-right:auto;line-height:1.35;}
.hero-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}
.hero-sm{min-height:56vh;padding:160px 32px 70px;}
.hero-sm h1{font-size:clamp(42px,7vw,76px);}

/* ---------- SECTIONS ---------- */
section{padding:120px 32px;position:relative;}
.section-label{font-family:'Kalam',cursive;font-weight:700;color:var(--rust);font-size:19px;text-align:center;margin-bottom:14px;}
.section-title{font-family:'Alfa Slab One',serif;font-size:clamp(38px,6vw,62px);color:var(--forest);text-align:center;margin-bottom:20px;line-height:1.05;}
.section-intro{text-align:center;max-width:680px;margin:0 auto 64px;font-size:18px;color:var(--forest);opacity:0.85;line-height:1.6;}

/* ---------- DIVIDER ---------- */
.divider-stamp{background:var(--forest);color:var(--bone);padding:22px 32px;font-family:'Alfa Slab One',serif;font-size:13px;letter-spacing:0.28em;text-transform:uppercase;overflow:hidden;position:relative;white-space:nowrap;}
.divider-track{display:inline-block;animation:slide 40s linear infinite;}
.divider-track span{padding:0 24px;}
.divider-track span::before{content:'';display:inline-block;width:8px;height:8px;background:var(--rust);border-radius:50%;margin-right:20px;transform:translateY(-2px);}
@keyframes slide{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ---------- HERO APP SHOWCASE (landing) ---------- */
.showcase{background:var(--bone);}
.showcase-inner{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:1fr 300px;gap:64px;align-items:center;}
.showcase-copy h2{font-size:clamp(34px,4.6vw,52px);color:var(--forest);margin-bottom:18px;line-height:1.04;}
.showcase-copy p{font-size:17px;line-height:1.7;margin-bottom:18px;color:var(--forest);}
.showcase-copy p strong{color:var(--rust);}
/* phone frame holding the dark app */
.phone{position:relative;width:300px;justify-self:center;}
.phone-frame{background:var(--navy-deep);border:3px solid var(--forest);border-radius:34px;padding:14px 12px;box-shadow:12px 12px 0 var(--rust);}
.phone-screen{background:#0f172a;border-radius:22px;overflow:hidden;padding:20px 16px;min-height:520px;color:#f1f5f9;font-family:'Archivo',sans-serif;}
.phone-notch{width:120px;height:22px;background:var(--navy-deep);border-radius:0 0 14px 14px;margin:-14px auto 14px;}
.app-h1{font-size:20px;font-weight:800;text-align:center;color:#f8fafc;margin-bottom:2px;letter-spacing:-0.01em;}
.app-sub{text-align:center;color:#94a3b8;font-size:12px;margin-bottom:16px;}
.app-card{background:#1e293b;border-radius:14px;padding:14px;margin-bottom:10px;}
.app-pot{background:#16a34a;color:#f0fdf4;border-radius:8px;padding:6px 10px;font-weight:700;font-size:14px;text-align:center;margin-bottom:10px;}
.app-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid #334155;font-size:14px;}
.app-row:last-child{border-bottom:none;}
.app-rank{width:22px;text-align:center;}
.app-name{flex:1;font-weight:600;}
.pos{color:#22c55e;font-weight:700;}
.neg{color:#ef4444;font-weight:700;}
.app-btn{background:#22c55e;color:#0f172a;border-radius:9px;padding:10px;text-align:center;font-weight:700;font-size:14px;margin-top:6px;}

/* ---------- FEATURES ---------- */
.features{background:var(--bone-2);}
.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:28px;max-width:1200px;margin:0 auto;}
.feature{background:var(--bone-light);padding:40px 28px;border:2px solid var(--forest);text-align:center;position:relative;transition:all 0.2s;}
.feature:hover{transform:translateY(-4px);box-shadow:6px 6px 0 var(--rust);}
.feature-icon{width:52px;height:52px;margin:0 auto 20px;color:var(--rust);stroke-width:1.8;}
.feature h3{font-size:22px;color:var(--forest);margin-bottom:10px;}
.feature p{font-size:14.5px;color:var(--forest);opacity:0.85;line-height:1.55;}
.feature .pro-flag{display:inline-block;margin-top:12px;font-family:'Alfa Slab One',serif;font-size:10px;letter-spacing:0.12em;color:var(--bone);background:var(--forest);padding:3px 10px;}

/* ---------- HOW IT WORKS ---------- */
.how{background:var(--bone);}
.steps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:28px;max-width:1200px;margin:0 auto;}
.step{background:var(--bone-light);padding:36px 28px 30px;border:2px solid var(--forest);position:relative;}
.step-num{position:absolute;top:-18px;left:20px;background:var(--rust);color:var(--bone);width:44px;height:44px;font-family:'Alfa Slab One',serif;font-size:18px;display:flex;align-items:center;justify-content:center;border:2.5px solid var(--forest);}
.step h3{font-size:20px;color:var(--forest);margin:16px 0 10px;}
.step p{font-size:14.5px;color:var(--forest);opacity:0.9;line-height:1.55;}

/* ---------- STORY (DARK) ---------- */
.story{position:relative;color:var(--bone);overflow:hidden;}
.story::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(28,42,56,0.78) 0%,rgba(28,42,56,0.90) 100%),var(--img-dark) center center/cover no-repeat;z-index:0;}
.story-content{position:relative;z-index:1;max-width:820px;margin:0 auto;text-align:center;}
.story .section-label{color:var(--rust-light);}
.story .section-title{color:var(--bone);}
.story-quote{font-family:'Kalam',cursive;font-weight:700;font-style:italic;font-size:clamp(22px,3vw,30px);color:var(--rust-light);margin:36px auto 32px;line-height:1.4;max-width:640px;}
.story-quote::before,.story-quote::after{content:'"';opacity:0.5;}
.story-body{font-size:17px;line-height:1.8;color:var(--bone);opacity:0.9;margin-bottom:20px;max-width:640px;margin-left:auto;margin-right:auto;}
.story-cta{margin-top:40px;}

/* ---------- PRICING ---------- */
.pricing{background:var(--bone-2);}
.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:28px;max-width:1000px;margin:0 auto;align-items:stretch;}
.price-card{background:var(--bone-light);border:2.5px solid var(--forest);padding:40px 32px;display:flex;flex-direction:column;position:relative;}
.price-card.featured{box-shadow:12px 12px 0 var(--rust);}
.price-card.featured::before{content:'BEST VALUE';position:absolute;top:-15px;left:28px;background:var(--rust);color:var(--bone);padding:6px 16px;font-family:'Alfa Slab One',serif;font-size:11px;letter-spacing:0.16em;}
.price-tier{font-family:'Alfa Slab One',serif;font-size:24px;color:var(--forest);margin-bottom:6px;}
.price-amt{font-family:'Alfa Slab One',serif;font-size:44px;color:var(--rust);line-height:1;margin:8px 0 2px;}
.price-amt small{font-family:'Archivo',sans-serif;font-size:15px;font-weight:600;color:var(--forest);opacity:0.7;}
.price-note{font-family:'Kalam',cursive;font-weight:700;font-style:italic;color:var(--forest);opacity:0.8;font-size:15px;margin-bottom:20px;}
.price-list{list-style:none;margin:0 0 24px;flex:1;}
.price-list li{font-size:14.5px;color:var(--forest);padding:7px 0 7px 26px;position:relative;line-height:1.4;border-bottom:1px dashed rgba(62,68,40,0.25);}
.price-list li::before{content:'✓';position:absolute;left:0;color:var(--rust);font-weight:700;}
.price-list li.no::before{content:'—';color:var(--tan);}

/* ---------- STORE BADGES ---------- */
.badges{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:8px;}
.store-badge{display:inline-flex;align-items:center;gap:12px;background:var(--forest);color:var(--bone);border:2px solid var(--forest);padding:12px 22px;border-radius:10px;transition:all 0.2s;min-width:200px;}
.store-badge:hover{background:var(--forest-deep);transform:translateY(-2px);}
.store-badge.soon{background:transparent;color:var(--forest);border:2px dashed var(--forest);cursor:default;}
.store-badge svg{width:26px;height:26px;flex-shrink:0;}
.store-badge .sb-small{font-family:'Archivo',sans-serif;font-size:10px;letter-spacing:0.1em;text-transform:uppercase;opacity:0.85;line-height:1.1;}
.store-badge .sb-big{font-family:'Alfa Slab One',serif;font-size:16px;line-height:1.15;letter-spacing:0.01em;}

/* ---------- TRUST / NOT GAMBLING ---------- */
.trust{background:var(--forest);color:var(--bone);}
.trust-card{max-width:820px;margin:0 auto;text-align:center;}
.trust .section-title{color:var(--bone);}
.trust .section-label{color:var(--rust-light);}
.trust p{font-size:17px;line-height:1.75;opacity:0.92;margin:0 auto 18px;max-width:680px;}
.trust strong{color:var(--rust-light);}

/* ---------- FAQ ---------- */
.faq{background:var(--bone);}
.faq-list{max-width:780px;margin:0 auto;}
.faq-item{border:2px solid var(--forest);background:var(--bone-light);margin-bottom:16px;}
.faq-item summary{list-style:none;cursor:pointer;padding:22px 26px;font-family:'Alfa Slab One',serif;font-size:18px;color:var(--forest);display:flex;justify-content:space-between;align-items:center;gap:16px;}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary::after{content:'+';color:var(--rust);font-size:28px;line-height:1;transition:transform 0.2s;}
.faq-item[open] summary::after{transform:rotate(45deg);}
.faq-item .faq-body{padding:0 26px 24px;font-size:15.5px;line-height:1.7;color:var(--forest);}
.faq-item .faq-body a{color:var(--rust);text-decoration:underline;}

/* ---------- FINAL CTA ---------- */
.final-cta{position:relative;color:var(--bone);overflow:hidden;text-align:center;}
.final-cta::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(28,42,56,0.80) 0%,rgba(28,42,56,0.94) 100%),var(--img-dark) center center/cover no-repeat;z-index:0;}
.final-cta-inner{position:relative;z-index:1;max-width:700px;margin:0 auto;}
.final-cta .section-title{color:var(--bone);}
.final-cta p{font-family:'Kalam',cursive;font-weight:700;font-style:italic;font-size:clamp(20px,2.6vw,26px);color:var(--rust-light);margin:18px auto 36px;}

/* ---------- FOOTER ---------- */
.footer{background:var(--navy);color:var(--bone);padding:80px 32px 32px;position:relative;overflow:hidden;}
.footer::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(28,42,56,0.80) 0%,rgba(28,42,56,0.95) 100%),var(--img-dark) center center/cover no-repeat;z-index:0;}
.footer-inner{position:relative;z-index:1;max-width:1200px;margin:0 auto;}
.footer-grid{display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:40px;margin-bottom:56px;}
.footer-logo{font-family:'Alfa Slab One',serif;font-size:22px;color:var(--bone);margin-bottom:16px;letter-spacing:0.02em;}
.footer h4{font-family:'Alfa Slab One',serif;font-size:14px;letter-spacing:0.12em;color:var(--rust-light);margin-bottom:18px;text-transform:uppercase;}
.footer ul{list-style:none;}
.footer li{margin-bottom:10px;}
.footer a,.footer li{color:var(--bone);opacity:0.78;font-size:14px;transition:opacity 0.2s,color 0.2s;}
.footer a:hover{opacity:1;color:var(--rust-light);}
.footer-about p{opacity:0.82;font-size:14px;line-height:1.6;margin-bottom:16px;max-width:400px;}
.footer-tagline{font-family:'Kalam',cursive;font-weight:700;font-style:italic;color:var(--rust-light);font-size:16px;opacity:1;}
.footer-bottom{position:relative;z-index:1;max-width:1200px;margin:0 auto;border-top:1px solid rgba(239,231,212,0.18);padding-top:28px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;font-size:13px;opacity:0.72;}

/* ---------- LEGAL / DELETION PAGES ---------- */
.story-full{background:var(--bone);padding:110px 32px;}
.story-full .container{max-width:780px;}
.story-block{margin-bottom:40px;}
.story-block h2{font-size:clamp(30px,4.4vw,46px);color:var(--forest);margin-bottom:20px;line-height:1.1;}
.story-block h3{font-family:'Alfa Slab One',serif;font-size:17px;color:var(--rust);margin-top:36px;margin-bottom:12px;letter-spacing:0.08em;text-transform:uppercase;}
.story-block p{font-size:17px;line-height:1.75;color:var(--forest);margin-bottom:16px;}
.story-block p strong{color:var(--rust);font-weight:600;}
.story-block a{color:var(--rust);text-decoration:underline;}
.story-block ul,.story-block ol{font-size:17px;line-height:1.7;color:var(--forest);margin:0 0 18px 24px;padding:0;}
.story-block li{margin-bottom:8px;}
.policy-short{background:var(--bone-light);border-left:4px solid var(--rust);padding:24px 28px;margin:0 0 40px;}
.policy-short strong{display:block;font-family:'Alfa Slab One',serif;font-size:14px;color:var(--rust);letter-spacing:0.12em;text-transform:uppercase;margin-bottom:8px;}
.policy-short p{font-family:'Kalam',cursive;font-weight:700;font-style:italic;font-size:22px!important;line-height:1.45!important;color:var(--forest);margin:0!important;}
.callout{border:2px solid var(--forest);background:var(--bone-light);padding:22px 26px;margin:28px 0;border-radius:4px;}
.callout strong{color:var(--rust);}
.callout.warn{border-color:var(--rust);background:#F6E6D9;}
.steps-ol{counter-reset:step;list-style:none!important;margin-left:0!important;}
.steps-ol li{position:relative;padding:4px 0 4px 44px;margin-bottom:14px;}
.steps-ol li::before{counter-increment:step;content:counter(step);position:absolute;left:0;top:2px;background:var(--rust);color:var(--bone);width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Alfa Slab One',serif;font-size:14px;}
.policy-meta{border-top:2px dashed var(--forest);margin-top:48px;padding-top:28px;font-family:'Archivo',sans-serif;font-size:14px;color:var(--forest);opacity:0.78;line-height:1.6;}
.toc{display:flex;flex-wrap:wrap;gap:10px;margin:0 0 8px;}
.toc a{font-family:'Archivo',sans-serif;font-size:12.5px;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;border:1.5px solid var(--forest);padding:6px 12px;color:var(--forest);text-decoration:none!important;transition:all 0.15s;}
.toc a:hover{background:var(--forest);color:var(--bone);}

/* ---------- UTILITIES ---------- */
.py-xl{padding-top:140px;padding-bottom:140px;}
.text-center{text-align:center;}

/* ---------- RESPONSIVE ---------- */
@media (max-width:980px){
  .showcase-inner{grid-template-columns:1fr;gap:48px;text-align:center;}
  .showcase-copy p{max-width:560px;margin-left:auto;margin-right:auto;}
}
@media (max-width:900px){
  .nav-links{display:none;position:fixed;top:68px;left:0;right:0;background:var(--bone);border-bottom:2px solid var(--forest);flex-direction:column;padding:24px 32px;gap:20px;}
  .nav-links.open{display:flex;}
  .nav-toggle{display:flex;}
  .hero{padding:140px 24px 80px;min-height:auto;}
  section{padding:80px 24px;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px;margin-bottom:40px;}
  .footer-bottom{flex-direction:column;text-align:center;}
}
@media (max-width:600px){
  .divider-stamp{font-size:11px;letter-spacing:0.18em;padding:18px 16px;}
  .hero-buttons{flex-direction:column;width:100%;max-width:300px;margin:0 auto;}
  .hero-buttons .btn{width:100%;}
  .footer-grid{grid-template-columns:1fr;}
  .store-badge{min-width:0;width:100%;justify-content:center;}
}
