/* ============================================================
   homepage.css — Tanzania Travel Discovery Platform (v13)
   Dark luxury · StoryBrand · search-led discovery. Prefix .tdp-
   ============================================================ */
.tdp{
  --gold:#d4a574; --gold-lt:#e8c4a0; --ink:#f3eee3; --mut:rgba(243,238,227,.62);
  --bg0:#0a0d0b; --bg1:#0e1311; --bg2:#121916; --line:rgba(212,165,116,.16);
  --glass:rgba(255,255,255,.04); --ease:cubic-bezier(.22,1,.36,1);
  --serif:"Cormorant Garamond",Georgia,serif; --sans:"Jost",sans-serif;
  --gut:clamp(1.25rem,5vw,5rem); --maxw:1280px;
  font-family:var(--sans);font-weight:300;color:var(--ink);background:transparent;line-height:1.6;overflow-x:hidden;
}
.tdp *{box-sizing:border-box}
.tdp ::selection{background:var(--gold);color:#0a0d0b}
/* sections sit over the site-wide background video: semi-transparent for readability,
   hero stays fully transparent so the video shows at full strength */
.tdp > section{position:relative;background:transparent}
.tdp > section.tdp-hero{background:transparent}
.tdp .wrap{max-width:var(--maxw);margin:0 auto;padding:clamp(4rem,9vh,7rem) var(--gut)}

/* reveal */
.tdp .r{opacity:0;transform:translateY(20px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.tdp .r.in{opacity:1;transform:none}
.tdp .r[data-d="1"]{transition-delay:.08s}.tdp .r[data-d="2"]{transition-delay:.16s}.tdp .r[data-d="3"]{transition-delay:.24s}.tdp .r[data-d="4"]{transition-delay:.32s}

/* type + shared */
.tdp .kick{font-size:.64rem;font-weight:500;letter-spacing:.32em;text-transform:uppercase;color:var(--gold-lt)}
.tdp .h2{font-family:var(--serif);font-weight:300;font-size:clamp(2.1rem,4.6vw,3.5rem);line-height:1.05;letter-spacing:-.015em;color:#fff;margin:.6rem 0 0;text-shadow:0 2px 24px rgba(0,0,0,.55)}
.tdp .h2 em{font-style:italic;color:var(--gold-lt)}
.tdp .sub{font-size:clamp(1rem,1.6vw,1.12rem);color:rgba(243,238,227,.8);max-width:54ch;margin-top:1rem;line-height:1.7;text-shadow:0 1px 16px rgba(0,0,0,.5)}
.tdp .shead{text-align:center;margin-bottom:clamp(2.2rem,4vw,3.2rem)}
.tdp .shead .sub{margin-left:auto;margin-right:auto}
.tdp .btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-family:var(--sans);font-size:.74rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;text-decoration:none;padding:1.05rem 2.1rem;border-radius:3px;border:1px solid transparent;cursor:pointer;transition:all .4s var(--ease)}
.tdp .btn--gold{background:var(--gold);color:#0a0d0b}
.tdp .btn--gold:hover{background:var(--gold-lt);transform:translateY(-2px)}
.tdp .btn--ghost{border-color:rgba(243,238,227,.4);color:#fff}
.tdp .btn--ghost:hover{border-color:var(--gold);color:var(--gold)}

/* ── 1. HERO ── */
.tdp-hero{min-height:92svh;display:flex;align-items:center;overflow:hidden}
.tdp-hero__bg{position:absolute;inset:0;z-index:1;pointer-events:none;background:
  linear-gradient(180deg,rgba(10,13,11,.20) 0%,rgba(10,13,11,.30) 50%,rgba(10,13,11,.60) 100%),
  radial-gradient(85% 75% at 80% 14%,rgba(212,165,116,.13),transparent 55%)}
.tdp-hero__in{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:0 var(--gut);width:100%}
.tdp-hero h1{font-family:var(--serif);font-weight:300;font-size:clamp(2.7rem,7vw,5.6rem);line-height:1;letter-spacing:-.02em;color:#fff;max-width:18ch;text-shadow:0 2px 40px rgba(0,0,0,.4)}
.tdp-hero h1 em{font-style:italic;color:var(--gold-lt)}
.tdp-hero__sub{margin-top:1.4rem;font-size:clamp(1rem,1.8vw,1.2rem);color:rgba(255,255,255,.86);max-width:50ch;line-height:1.7}
/* search — the signature */
.tdp-search{margin-top:2rem;max-width:600px;background:rgba(12,15,13,.72);border:1px solid var(--line);border-radius:5px;padding:.5rem;display:flex;gap:.5rem;box-shadow:0 24px 60px rgba(0,0,0,.4)}
.tdp-search input{flex:1;background:transparent;border:0;outline:0;color:#fff;font-family:var(--sans);font-size:1rem;padding:.85rem 1rem}
.tdp-search input::placeholder{color:rgba(243,238,227,.45)}
.tdp-search button{flex:none}
.tdp-chips{margin-top:1rem;display:flex;flex-wrap:wrap;gap:.5rem}
.tdp-chips span{font-size:.68rem;color:var(--mut);margin-right:.2rem;align-self:center}
.tdp-chips a{font-size:.72rem;letter-spacing:.04em;color:var(--gold-lt);text-decoration:none;border:1px solid var(--line);border-radius:30px;padding:.4rem .9rem;transition:all .3s}
.tdp-chips a:hover{border-color:var(--gold);background:rgba(212,165,116,.1)}
.tdp-hero__cta{margin-top:1.8rem;display:flex;gap:.7rem;flex-wrap:wrap}

/* ── 2. PROBLEM ── */
.tdp-prob{background:var(--bg1)}
.tdp-prob__grid{display:grid;gap:1rem;grid-template-columns:1fr}
.tdp-pcard{background:var(--bg2);border:1px solid var(--line);border-radius:6px;padding:1.6rem 1.5rem}
.tdp-pcard h3{font-family:var(--sans);font-weight:500;font-size:.95rem;color:#fff;margin:0 0 .4rem;letter-spacing:.01em}
.tdp-pcard p{font-size:.86rem;color:var(--mut);line-height:1.6}
.tdp-pcard .ic{font-size:1.3rem;margin-bottom:.7rem;display:block}
@media(min-width:640px){.tdp-prob__grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:980px){.tdp-prob__grid{grid-template-columns:repeat(5,1fr)}}

/* ── 3. SOLUTION ── */
.tdp-sol__grid{display:grid;gap:1rem;grid-template-columns:repeat(2,1fr)}
.tdp-fcard{position:relative;background:rgba(12,16,14,.55);border:1px solid var(--line);border-radius:8px;padding:1.7rem 1.4rem;text-decoration:none;display:block;transition:all .4s var(--ease)}
.tdp-fcard:hover{border-color:var(--gold);transform:translateY(-3px);background:rgba(212,165,116,.06)}
.tdp-fcard .ic{font-size:1.5rem;display:block;margin-bottom:.8rem}
.tdp-fcard h3{font-family:var(--serif);font-size:1.3rem;font-weight:500;color:#fff;margin:0 0 .25rem}
.tdp-fcard p{font-size:.8rem;color:var(--mut)}
@media(min-width:760px){.tdp-sol__grid{grid-template-columns:repeat(4,1fr)}}

/* ── 4. EXPLORE (destinations) ── */
.tdp-dest{background:var(--bg1)}
.tdp-dgrid{display:grid;gap:1.1rem;grid-template-columns:1fr}
.tdp-dcard{position:relative;aspect-ratio:3/4;border-radius:10px;overflow:hidden;text-decoration:none;box-shadow:0 24px 50px rgba(0,0,0,.45)}
.tdp-dcard__img{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform 1s var(--ease)}
.tdp-dcard:hover .tdp-dcard__img{transform:scale(1.06)}
.tdp-dcard__sh{position:absolute;inset:0;background:linear-gradient(180deg,transparent 35%,rgba(8,11,9,.9))}
.tdp-dcard__c{position:absolute;left:0;right:0;bottom:0;padding:1.4rem}
.tdp-dcard__tag{font-size:.56rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-lt)}
.tdp-dcard h3{font-family:var(--serif);font-size:1.7rem;font-weight:500;color:#fff;margin:.2rem 0 0;line-height:1}
.tdp-dcard p{font-size:.78rem;color:rgba(243,238,227,.7);margin-top:.3rem}
@media(min-width:560px){.tdp-dgrid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:980px){.tdp-dgrid{grid-template-columns:repeat(4,1fr)}}
.tdp-soon{margin-top:1.5rem;text-align:center;font-size:.8rem;color:var(--mut)}
.tdp-soon b{color:var(--gold-lt);font-weight:500}

/* ── 5. EXPERIENCES ── */
.tdp-xgrid{display:grid;gap:.9rem;grid-template-columns:repeat(2,1fr)}
.tdp-xcard{position:relative;aspect-ratio:1/1;border-radius:8px;overflow:hidden;text-decoration:none}
.tdp-xcard__img{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .8s var(--ease)}
.tdp-xcard:hover .tdp-xcard__img{transform:scale(1.07)}
.tdp-xcard__sh{position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(8,11,9,.85))}
.tdp-xcard span{position:absolute;left:0;right:0;bottom:0;padding:1rem;font-family:var(--serif);font-size:1.15rem;color:#fff;font-weight:500}
@media(min-width:680px){.tdp-xgrid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:980px){.tdp-xgrid{grid-template-columns:repeat(5,1fr)}}

/* ── 6. TOOLS ── */
.tdp-tools{background:var(--bg1)}
.tdp-tgrid{display:grid;gap:1rem;grid-template-columns:1fr}
.tdp-tcard{display:flex;align-items:center;gap:1rem;background:var(--bg2);border:1px solid var(--line);border-radius:8px;padding:1.3rem 1.4rem;text-decoration:none;transition:all .35s var(--ease)}
.tdp-tcard:hover{border-color:var(--gold);transform:translateY(-2px)}
.tdp-tcard .ic{font-size:1.5rem}
.tdp-tcard h3{font-family:var(--sans);font-weight:500;font-size:.95rem;color:#fff;margin:0}
.tdp-tcard p{font-size:.76rem;color:var(--mut);margin:.15rem 0 0}
.tdp-tcard .soon{margin-left:auto;font-size:.55rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-lt);border:1px solid var(--line);padding:.2rem .5rem;border-radius:20px;white-space:nowrap}
@media(min-width:680px){.tdp-tgrid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1040px){.tdp-tgrid{grid-template-columns:repeat(3,1fr)}}

/* ── 7. GUIDES ── */
.tdp-ggrid{display:grid;gap:1.1rem;grid-template-columns:1fr}
.tdp-gcard{border-radius:8px;overflow:hidden;text-decoration:none;background:var(--bg2);border:1px solid var(--line);transition:all .4s var(--ease)}
.tdp-gcard:hover{transform:translateY(-3px);border-color:var(--gold)}
.tdp-gcard__img{aspect-ratio:16/10;background-size:cover;background-position:center}
.tdp-gcard__b{padding:1.2rem 1.3rem 1.4rem}
.tdp-gcard__tag{font-size:.56rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-lt)}
.tdp-gcard h3{font-family:var(--serif);font-size:1.3rem;font-weight:500;color:#fff;margin:.3rem 0 0;line-height:1.15}
@media(min-width:680px){.tdp-ggrid{grid-template-columns:repeat(3,1fr)}}

/* ── 8. TRUST ── */
.tdp-trust{background:var(--bg1);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.tdp-tstats{display:grid;gap:1.5rem;grid-template-columns:repeat(2,1fr);text-align:center}
.tdp-tstat .n{font-family:var(--serif);font-size:clamp(2.2rem,5vw,3.4rem);color:var(--gold-lt);line-height:1;text-shadow:0 2px 20px rgba(0,0,0,.5)}
.tdp-tstat .l{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--mut);margin-top:.4rem}
@media(min-width:880px){.tdp-tstats{grid-template-columns:repeat(5,1fr)}}

/* ── 9. FINAL ── */
.tdp-final{text-align:center}
.tdp-final .btnrow{display:flex;gap:.7rem;justify-content:center;flex-wrap:wrap;margin-top:1.8rem}

@media(prefers-reduced-motion:reduce){.tdp .r{opacity:1;transform:none;transition:none}}
