/* ============================================================
   PT — Permanent Traveler  |  style.css
   Earthy expedition palette: forest green + terracotta + warm cream
   ============================================================ */

/* ── TOKENS ──────────────────────────────────────────────────*/
:root {
  --text-xs:   clamp(0.75rem,  0.7rem  + 0.25vw, 0.875rem);
  --text-sm:   clamp(0.875rem, 0.8rem  + 0.35vw, 1rem);
  --text-base: clamp(1rem,     0.95rem + 0.25vw, 1.125rem);
  --text-lg:   clamp(1.125rem, 1rem    + 0.75vw, 1.5rem);
  --text-xl:   clamp(1.5rem,   1.2rem  + 1.25vw, 2.25rem);
  --text-2xl:  clamp(2rem,     1.2rem  + 2.5vw,  3.5rem);
  --text-hero: clamp(3rem,     1rem    + 7vw,     7rem);

  --space-1:0.25rem; --space-2:0.5rem;  --space-3:0.75rem; --space-4:1rem;
  --space-5:1.25rem; --space-6:1.5rem;  --space-8:2rem;    --space-10:2.5rem;
  --space-12:3rem;   --space-16:4rem;   --space-20:5rem;   --space-24:6rem;

  --radius-sm:0.375rem; --radius-md:0.5rem; --radius-lg:0.75rem;
  --radius-xl:1rem;     --radius-2xl:1.5rem; --radius-full:9999px;

  --tr: 180ms cubic-bezier(0.16,1,0.3,1);

  --content-wide: 1240px;
  --content-default: 960px;
  --font-display: 'Playfair Display', Georgia, serif;
  --font-body:    'Inter', system-ui, sans-serif;
}

:root, [data-theme="light"] {
  --color-bg:              #f6f4ef;
  --color-surface:         #faf8f4;
  --color-surface-2:       #fffefb;
  --color-surface-offset:  #ede9e2;
  --color-divider:         #ddd8d0;
  --color-border:          #ccc7bc;
  --color-text:            #1e1c18;
  --color-text-muted:      #6b6860;
  --color-text-faint:      #b0ada7;
  --color-text-inverse:    #faf8f4;
  --color-primary:         #1e5c3a;
  --color-primary-hover:   #174a2e;
  --color-primary-light:   #4a8f6a;
  --color-primary-highlight: #d2e4da;
  --color-accent:          #c1541e;
  --color-accent-hover:    #a24016;
  --color-accent-highlight:#f2ddd3;
  --color-success:         #3a7d1e;
  --shadow-sm: 0 1px 3px rgba(30,40,30,0.08);
  --shadow-md: 0 4px 16px rgba(30,40,30,0.12);
  --shadow-lg: 0 12px 40px rgba(30,40,30,0.18);
  --shadow-xl: 0 24px 64px rgba(30,40,30,0.24);
}

[data-theme="dark"] {
  --color-bg:              #141210;
  --color-surface:         #1a1816;
  --color-surface-2:       #1f1d1a;
  --color-surface-offset:  #171512;
  --color-divider:         #2a2823;
  --color-border:          #383530;
  --color-text:            #e0ddd8;
  --color-text-muted:      #7a7872;
  --color-text-faint:      #504e4a;
  --color-text-inverse:    #141210;
  --color-primary:         #5daa7a;
  --color-primary-hover:   #3d8c5e;
  --color-primary-light:   #7dbf96;
  --color-primary-highlight:#1e3228;
  --color-accent:          #e07848;
  --color-accent-hover:    #c85e30;
  --color-accent-highlight:#3a2418;
  --color-success:         #62a842;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.3);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.4);
  --shadow-lg: 0 12px 40px rgba(0,0,0,0.5);
  --shadow-xl: 0 24px 64px rgba(0,0,0,0.6);
}

@media (prefers-color-scheme:dark) {
  :root:not([data-theme]) {
    --color-bg:#141210; --color-surface:#1a1816; --color-surface-2:#1f1d1a;
    --color-surface-offset:#171512; --color-divider:#2a2823; --color-border:#383530;
    --color-text:#e0ddd8; --color-text-muted:#7a7872; --color-text-faint:#504e4a;
    --color-text-inverse:#141210;
    --color-primary:#5daa7a; --color-primary-hover:#3d8c5e; --color-primary-light:#7dbf96;
    --color-primary-highlight:#1e3228;
    --color-accent:#e07848; --color-accent-hover:#c85e30; --color-accent-highlight:#3a2418;
    --color-success:#62a842;
    --shadow-sm:0 1px 3px rgba(0,0,0,0.3); --shadow-md:0 4px 16px rgba(0,0,0,0.4);
    --shadow-lg:0 12px 40px rgba(0,0,0,0.5); --shadow-xl:0 24px 64px rgba(0,0,0,0.6);
  }
}

/* ── RESET ───────────────────────────────────────────────────*/
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:none;text-size-adjust:none;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;scroll-behavior:smooth;scroll-padding-top:80px}
body{min-height:100dvh;line-height:1.6;font-family:var(--font-body);font-size:var(--text-base);
  color:var(--color-text);background:var(--color-bg)}
img,picture,video{display:block;max-width:100%;height:auto}
ul[role=list],ol[role=list]{list-style:none}
input,button,textarea,select{font:inherit;color:inherit}
h1,h2,h3,h4,h5,h6{text-wrap:balance;line-height:1.15}
p,li{text-wrap:pretty;max-width:72ch}
button{cursor:pointer;background:none;border:none}
a{text-decoration:none;color:inherit}
::selection{background:rgba(30,92,58,0.18)}
:focus-visible{outline:2px solid var(--color-primary);outline-offset:3px;border-radius:var(--radius-sm)}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}}

/* ── UTILS ───────────────────────────────────────────────────*/
.container{max-width:var(--content-wide);margin:0 auto;padding:0 var(--space-6)}

/* ── BUTTONS ─────────────────────────────────────────────────*/
.btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);
  font-size:var(--text-sm);font-weight:600;letter-spacing:.01em;border-radius:var(--radius-full);
  border:2px solid transparent;white-space:nowrap;
  transition:background var(--tr),color var(--tr),border-color var(--tr),box-shadow var(--tr),transform var(--tr)}
.btn:hover{transform:translateY(-1px)} .btn:active{transform:translateY(0)}
.btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}
.btn-primary:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover)}
.btn-outline{background:transparent;color:var(--color-primary);border-color:var(--color-primary)}
.btn-outline:hover{background:var(--color-primary-highlight)}
.btn-ghost{background:transparent;color:rgba(255,255,255,0.9);border-color:rgba(255,255,255,0.4)}
.btn-ghost:hover{background:rgba(255,255,255,0.15);border-color:rgba(255,255,255,0.7)}
.btn-accent{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}
.btn-accent:hover{background:var(--color-accent-hover)}
.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--text-base)}

/* ── HEADER ──────────────────────────────────────────────────*/
.header{position:sticky;top:0;z-index:100;background:rgba(246,244,239,0.92);
  backdrop-filter:blur(16px) saturate(1.5);border-bottom:1px solid var(--color-divider);
  transition:box-shadow var(--tr)}
[data-theme=dark] .header{background:rgba(20,18,16,0.92)}
.header--scrolled{box-shadow:var(--shadow-md)}
.header-inner{max-width:var(--content-wide);margin:0 auto;padding:0 var(--space-6);
  display:flex;align-items:center;gap:var(--space-6);height:68px}
.logo{display:flex;align-items:center;gap:var(--space-3)}
.logo-mark{width:38px;height:38px;border-radius:var(--radius-md);background:var(--color-primary);
  color:#fff;font-family:var(--font-display);font-weight:900;font-size:1rem;
  display:flex;align-items:center;justify-content:center;letter-spacing:-.03em;flex-shrink:0}
.logo-text{font-family:var(--font-display);font-weight:700;font-size:var(--text-base);color:var(--color-text)}
.nav{display:flex;align-items:center;gap:var(--space-1);margin-left:auto}
.nav-link{padding:var(--space-2) var(--space-3);font-size:var(--text-sm);font-weight:500;
  color:var(--color-text-muted);border-radius:var(--radius-md);
  transition:color var(--tr),background var(--tr)}
.nav-link:hover{color:var(--color-text);background:var(--color-surface-offset)}
.header-actions{display:flex;align-items:center;gap:var(--space-3)}
.theme-toggle{width:36px;height:36px;border-radius:var(--radius-full);display:flex;
  align-items:center;justify-content:center;color:var(--color-text-muted);
  transition:color var(--tr),background var(--tr)}
.theme-toggle:hover{background:var(--color-surface-offset);color:var(--color-text)}
.nav-mobile-toggle{display:none;color:var(--color-text);padding:var(--space-2)}
.mobile-nav{display:none;flex-direction:column;padding:var(--space-4) var(--space-6);
  border-top:1px solid var(--color-divider);background:var(--color-surface)}
.mobile-nav .nav-link{padding:var(--space-3) 0;border-bottom:1px solid var(--color-divider)}
.mobile-nav.open{display:flex}
/* user chip */
.user-chip{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);
  background:var(--color-primary-highlight);border-radius:var(--radius-full);
  font-size:var(--text-xs);font-weight:600;color:var(--color-primary);cursor:pointer}
@media(max-width:860px){.nav{display:none}.nav-mobile-toggle{display:flex}}

/* ── PAGE SECTIONS ───────────────────────────────────────────*/
.page-section{display:none}
.page-section.active{display:block}

/* ── HERO ────────────────────────────────────────────────────*/
.hero{position:relative;min-height:92dvh;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0}
.hero-img{width:100%;height:100%;object-fit:cover;object-position:center 40%}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(160deg,
  rgba(10,40,20,0.85) 0%,rgba(10,30,18,0.6) 50%,rgba(20,10,5,0.5) 100%)}
.hero-content{position:relative;z-index:2;max-width:var(--content-wide);width:100%;
  margin:0 auto;padding:var(--space-20) var(--space-6)}
.hero-badge{display:inline-flex;align-items:center;gap:var(--space-2);
  background:rgba(255,255,255,0.12);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,0.2);color:rgba(255,255,255,0.9);
  padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);
  font-size:var(--text-sm);font-weight:500;margin-bottom:var(--space-6)}
.hero-title{font-family:var(--font-display);font-size:var(--text-hero);font-weight:900;
  color:#fff;line-height:1.05;margin-bottom:var(--space-6)}
.hero-title em{color:#f0c078;font-style:italic}
.hero-sub{font-size:var(--text-lg);color:rgba(255,255,255,0.85);max-width:560px;
  line-height:1.6;margin-bottom:var(--space-10)}
.hero-cta{display:flex;gap:var(--space-4);flex-wrap:wrap;margin-bottom:var(--space-12)}
.hero-stats{display:flex;align-items:center;gap:var(--space-6);flex-wrap:wrap}
.stat{display:flex;flex-direction:column;gap:var(--space-1)}
.stat-num{font-family:var(--font-display);font-size:var(--text-xl);font-weight:900;color:#fff;line-height:1}
.stat-label{font-size:var(--text-xs);color:rgba(255,255,255,0.6);text-transform:uppercase;letter-spacing:.1em}
.stat-divider{width:1px;height:40px;background:rgba(255,255,255,0.2)}
.scroll-cue{position:absolute;bottom:var(--space-8);left:50%;transform:translateX(-50%);
  z-index:2;color:rgba(255,255,255,0.6);animation:bounce 2s ease-in-out infinite}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}

/* ── SEARCH ──────────────────────────────────────────────────*/
.search-section{background:var(--color-surface);border-bottom:1px solid var(--color-divider);
  padding:var(--space-5) var(--space-6);position:sticky;top:68px;z-index:90}
.search-bar-wrap{max-width:var(--content-wide);margin:0 auto}
.search-form{display:flex;align-items:center;background:var(--color-bg);
  border:1.5px solid var(--color-border);border-radius:var(--radius-full);overflow:hidden;
  box-shadow:var(--shadow-sm);transition:border-color var(--tr),box-shadow var(--tr)}
.search-form:focus-within{border-color:var(--color-primary);
  box-shadow:0 0 0 3px var(--color-primary-highlight)}
.search-field{display:flex;align-items:center;gap:var(--space-3);
  padding:var(--space-3) var(--space-5);flex:1;min-width:0}
.search-icon{color:var(--color-text-muted);flex-shrink:0}
.search-field input{border:none;background:transparent;outline:none;
  font-size:var(--text-sm);color:var(--color-text);width:100%}
.search-field input::placeholder{color:var(--color-text-faint)}
.search-divider{width:1px;height:28px;background:var(--color-divider);flex-shrink:0}
.search-form select{border:none;background:transparent;outline:none;font-size:var(--text-sm);
  color:var(--color-text-muted);padding:var(--space-3) var(--space-4);cursor:pointer}
.search-form .btn{margin:var(--space-2)}
@media(max-width:700px){
  .search-form{flex-direction:column;border-radius:var(--radius-xl);align-items:stretch}
  .search-divider{width:100%;height:1px}
  .search-form .btn{margin:var(--space-3)}}

/* ── SECTION SHARED ──────────────────────────────────────────*/
.section-eyebrow{font-size:var(--text-xs);font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--color-primary);margin-bottom:var(--space-3)}
.section-title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:900;
  color:var(--color-text);line-height:1.1;margin-bottom:var(--space-10)}
.section-header{display:flex;align-items:flex-start;justify-content:space-between;
  flex-wrap:wrap;gap:var(--space-6);margin-bottom:var(--space-10)}
.section-header .section-title{margin-bottom:0}

/* ── CHIPS ───────────────────────────────────────────────────*/
.filter-chips{display:flex;gap:var(--space-2);flex-wrap:wrap;align-items:center}
.chip{padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);
  font-size:var(--text-xs);font-weight:600;border:1.5px solid var(--color-border);
  color:var(--color-text-muted);background:var(--color-surface);
  transition:all var(--tr);white-space:nowrap}
.chip:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-highlight)}
.chip-active{background:var(--color-primary)!important;color:#fff!important;border-color:var(--color-primary)!important}

/* ── PROJECTS ────────────────────────────────────────────────*/
.projects-section{padding:clamp(var(--space-12),6vw,var(--space-24)) 0}
.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:var(--space-6)}
.project-card{background:var(--color-surface);border-radius:var(--radius-2xl);overflow:hidden;
  border:1px solid var(--color-divider);box-shadow:var(--shadow-sm);cursor:pointer;
  display:flex;flex-direction:column;
  transition:transform var(--tr),box-shadow var(--tr),border-color var(--tr)}
.project-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--color-primary-highlight)}
.project-card-img{position:relative;height:200px;overflow:hidden}
.project-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.project-card:hover .project-card-img img{transform:scale(1.05)}
.project-card-badge{position:absolute;top:var(--space-3);left:var(--space-3);background:var(--color-primary);
  color:#fff;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:700}
.project-card-urgency{position:absolute;top:var(--space-3);right:var(--space-3);background:var(--color-accent);
  color:#fff;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:700}
.project-card-body{padding:var(--space-5);flex:1;display:flex;flex-direction:column}
.project-card-location{display:flex;align-items:center;gap:var(--space-2);
  font-size:var(--text-xs);color:var(--color-text-muted);margin-bottom:var(--space-2)}
.project-card-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:700;
  color:var(--color-text);line-height:1.2;margin-bottom:var(--space-3)}
.project-card-desc{font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.6;flex:1}
.project-card-footer{display:flex;align-items:center;justify-content:space-between;
  margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--color-divider)}
.project-card-meta{display:flex;gap:var(--space-4)}
.project-meta-item{display:flex;align-items:center;gap:var(--space-1);font-size:var(--text-xs);color:var(--color-text-muted)}
.project-card-cta{font-size:var(--text-xs);font-weight:700;color:var(--color-primary);
  display:flex;align-items:center;gap:var(--space-1);transition:gap var(--tr)}
.project-card:hover .project-card-cta{gap:var(--space-2)}
.load-more-wrap{display:flex;justify-content:center;margin-top:var(--space-12)}

/* spinner */
.loading-spinner{grid-column:1/-1;display:flex;justify-content:center;align-items:center;padding:var(--space-16)}
.spinner{width:40px;height:40px;border:3px solid var(--color-divider);
  border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── HOW IT WORKS ────────────────────────────────────────────*/
.how-section{padding:clamp(var(--space-12),6vw,var(--space-24)) 0;background:var(--color-surface)}
.steps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-8)}
.step-num{font-family:var(--font-display);font-size:clamp(3rem,5vw,5.5rem);font-weight:900;
  line-height:1;color:var(--color-primary-highlight);margin-bottom:var(--space-4);transition:color var(--tr)}
.step:hover .step-num{color:var(--color-primary)}
.step-icon{font-size:2.2rem;margin-bottom:var(--space-3)}
.step-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:700;
  margin-bottom:var(--space-3);color:var(--color-text)}
.step-desc{font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.7}

/* ── REGIONS ─────────────────────────────────────────────────*/
.regions-section{padding:clamp(var(--space-12),6vw,var(--space-24)) 0}
.regions-grid{display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:auto auto;gap:var(--space-4)}
.region-card--large{grid-column:1;grid-row:1/3}
.region-card{position:relative;border-radius:var(--radius-2xl);overflow:hidden;cursor:pointer;min-height:200px}
.region-card--large{min-height:420px}
.region-card img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.region-card:hover img{transform:scale(1.06)}
.region-overlay{position:absolute;inset:0;
  background:linear-gradient(to top,rgba(10,30,15,0.85) 0%,transparent 55%);
  display:flex;flex-direction:column;justify-content:flex-end;padding:var(--space-5)}
.region-count{font-size:var(--text-xs);color:rgba(255,255,255,0.7);font-weight:600;letter-spacing:.08em;margin-bottom:var(--space-1)}
.region-name{font-family:var(--font-display);font-size:var(--text-xl);font-weight:900;color:#fff}
@media(max-width:800px){.regions-grid{grid-template-columns:1fr 1fr}.region-card--large{grid-column:1/-1;grid-row:auto;min-height:240px}}
@media(max-width:520px){.regions-grid{grid-template-columns:1fr}}

/* ── TESTIMONIALS ────────────────────────────────────────────*/
.testimonials-section{padding:clamp(var(--space-12),6vw,var(--space-24)) 0;background:var(--color-surface)}
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6)}
.testimonial{background:var(--color-bg);border:1px solid var(--color-divider);
  border-radius:var(--radius-2xl);padding:var(--space-8);position:relative;overflow:hidden}
.testimonial--featured{background:var(--color-primary);border-color:var(--color-primary);color:#fff}
.testimonial--featured .testimonial-body{color:rgba(255,255,255,0.92)}
.testimonial--featured .testimonial-name{color:#fff}
.testimonial--featured .testimonial-detail{color:rgba(255,255,255,0.7)}
.testimonial-quote{font-family:var(--font-display);font-size:6rem;line-height:.6;
  color:rgba(255,255,255,0.15);position:absolute;top:var(--space-4);left:var(--space-6);font-weight:900}
.testimonial-body{font-size:var(--text-sm);line-height:1.8;color:var(--color-text-muted);
  margin-bottom:var(--space-6);position:relative;z-index:1}
.testimonial-author{display:flex;align-items:center;gap:var(--space-3)}
.testimonial-avatar{width:44px;height:44px;border-radius:var(--radius-full);flex-shrink:0;
  background:var(--color-primary-highlight);color:var(--color-primary);
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--text-sm)}
.testimonial--featured .testimonial-avatar{background:rgba(255,255,255,0.2);color:#fff}
.testimonial-name{font-weight:700;font-size:var(--text-sm);color:var(--color-text)}
.testimonial-detail{font-size:var(--text-xs);color:var(--color-text-muted)}
@media(max-width:860px){.testimonials-grid{grid-template-columns:1fr;max-width:560px;margin:0 auto}}

/* ── HOST SECTION ────────────────────────────────────────────*/
.host-section{padding:clamp(var(--space-12),6vw,var(--space-24)) 0;
  background:linear-gradient(135deg,var(--color-primary) 0%,#0f3522 100%);color:#fff}
.host-inner{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-16);align-items:center}
.host-title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:900;
  color:#fff;line-height:1.1;margin-bottom:var(--space-5)}
.host-desc{font-size:var(--text-base);color:rgba(255,255,255,0.85);line-height:1.7;margin-bottom:var(--space-8)}
.host-benefits{list-style:none;margin-bottom:var(--space-8);display:flex;flex-direction:column;gap:var(--space-3)}
.host-benefits li{font-size:var(--text-sm);color:rgba(255,255,255,0.9)}
.host-section .btn-primary{background:#fff;color:var(--color-primary);border-color:#fff}
.host-section .btn-primary:hover{background:rgba(255,255,255,0.9)}
.host-visual{border-radius:var(--radius-2xl);overflow:hidden;box-shadow:var(--shadow-xl)}
.host-visual img{width:100%;height:400px;object-fit:cover}
@media(max-width:860px){.host-inner{grid-template-columns:1fr}.host-visual{order:-1}.host-visual img{height:260px}}

/* ── DONATE TEASER ───────────────────────────────────────────*/
.donate-teaser{padding:clamp(var(--space-10),4vw,var(--space-16)) 0;background:var(--color-accent-highlight)}
.donate-teaser-inner{display:flex;align-items:center;justify-content:space-between;gap:var(--space-8);flex-wrap:wrap}
.donate-teaser-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:900;color:var(--color-text);margin-bottom:var(--space-3)}
.donate-teaser p{font-size:var(--text-sm);color:var(--color-text-muted)}

/* ── FOOTER ──────────────────────────────────────────────────*/
.footer{background:var(--color-text);color:rgba(255,255,255,0.85);padding:var(--space-16) 0 var(--space-8)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:var(--space-8);margin-bottom:var(--space-12)}
.footer-brand .logo-mark{background:var(--color-primary-light)}
.footer-brand .logo-text{color:rgba(255,255,255,0.9)}
.footer-tagline{font-size:var(--text-sm);color:rgba(255,255,255,0.5);line-height:1.7;margin-top:var(--space-4);margin-bottom:var(--space-6)}
.footer-social{display:flex;gap:var(--space-3)}
.social-link{width:38px;height:38px;border-radius:var(--radius-full);border:1px solid rgba(255,255,255,0.15);
  display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.6);
  transition:color var(--tr),border-color var(--tr),background var(--tr)}
.social-link:hover{color:#fff;border-color:rgba(255,255,255,0.4);background:rgba(255,255,255,0.08)}
.footer-heading{font-size:var(--text-xs);font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:rgba(255,255,255,0.35);margin-bottom:var(--space-4)}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:var(--space-3)}
.footer-links a{font-size:var(--text-sm);color:rgba(255,255,255,0.6);transition:color var(--tr)}
.footer-links a:hover{color:#fff}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-4);
  padding-top:var(--space-8);border-top:1px solid rgba(255,255,255,0.08)}
.footer-copy{font-size:var(--text-xs);color:rgba(255,255,255,0.3)}
.footer-legal{display:flex;gap:var(--space-6)}
.footer-legal a{font-size:var(--text-xs);color:rgba(255,255,255,0.3);transition:color var(--tr)}
.footer-legal a:hover{color:rgba(255,255,255,0.7)}
@media(max-width:860px){.footer-grid{grid-template-columns:1fr 1fr}.footer-brand{grid-column:1/-1}}
@media(max-width:520px){.footer-grid{grid-template-columns:1fr}}

/* ── MODAL ───────────────────────────────────────────────────*/
.modal-overlay{position:fixed;inset:0;z-index:200;background:rgba(10,25,15,0.7);
  backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;
  padding:var(--space-6);opacity:0;pointer-events:none;transition:opacity var(--tr)}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal{background:var(--color-surface);border-radius:var(--radius-2xl);max-width:600px;
  width:100%;max-height:88dvh;overflow-y:auto;position:relative;box-shadow:var(--shadow-xl);
  transform:translateY(20px) scale(0.97);transition:transform var(--tr)}
.modal-overlay.open .modal{transform:translateY(0) scale(1)}
.modal-close{position:absolute;top:var(--space-5);right:var(--space-5);z-index:2;width:36px;height:36px;
  border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;
  background:var(--color-surface-offset);color:var(--color-text-muted);
  transition:background var(--tr),color var(--tr)}
.modal-close:hover{background:var(--color-divider);color:var(--color-text)}
.modal-content{padding:var(--space-8)}
/* modal project detail */
.modal-project-img{width:100%;height:220px;object-fit:cover;border-radius:var(--radius-xl);margin-bottom:var(--space-6)}
.modal-tag{display:inline-flex;padding:var(--space-1) var(--space-3);
  background:var(--color-primary-highlight);color:var(--color-primary);
  font-size:var(--text-xs);font-weight:700;border-radius:var(--radius-full);margin-bottom:var(--space-4)}
.modal-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:900;
  color:var(--color-text);margin-bottom:var(--space-2)}
.modal-location{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);
  color:var(--color-text-muted);margin-bottom:var(--space-5)}
.modal-desc{font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.8;margin-bottom:var(--space-6)}
.modal-details{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4);margin-bottom:var(--space-6)}
.modal-detail-item{background:var(--color-surface-offset);border-radius:var(--radius-lg);padding:var(--space-4)}
.modal-detail-label{font-size:var(--text-xs);color:var(--color-text-faint);font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-1)}
.modal-detail-value{font-size:var(--text-sm);color:var(--color-text);font-weight:600}
.modal-form-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:700;margin-bottom:var(--space-5);color:var(--color-text)}
.modal-divider{height:1px;background:var(--color-divider);margin:var(--space-6) 0}

/* ── FORMS ───────────────────────────────────────────────────*/
.form-label{display:block;font-size:var(--text-xs);font-weight:600;color:var(--color-text-muted);
  margin-bottom:var(--space-2)}
.form-input{width:100%;padding:var(--space-3) var(--space-4);border:1.5px solid var(--color-border);
  border-radius:var(--radius-lg);background:var(--color-bg);color:var(--color-text);
  font-size:var(--text-sm);margin-bottom:var(--space-4);transition:border-color var(--tr)}
.form-input:focus{outline:none;border-color:var(--color-primary)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}
.form-section-heading{font-family:var(--font-display);font-size:var(--text-xl);font-weight:700;
  margin-bottom:var(--space-6);color:var(--color-text)}
@media(max-width:600px){.form-row{grid-template-columns:1fr}}

/* join / login modal */
.join-wrap{text-align:center}
.join-icon{font-size:2.8rem;margin-bottom:var(--space-4)}
.join-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:900;margin-bottom:var(--space-2)}
.join-sub{font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-8)}
.join-tabs{display:flex;gap:0;margin-bottom:var(--space-6);border-radius:var(--radius-lg);
  overflow:hidden;border:1.5px solid var(--color-border)}
.join-tab{flex:1;padding:var(--space-3);font-size:var(--text-sm);font-weight:600;
  color:var(--color-text-muted);background:var(--color-bg);transition:all var(--tr)}
.join-tab.active{background:var(--color-primary);color:#fff}
.join-divider{display:flex;align-items:center;gap:var(--space-4);margin:var(--space-5) 0}
.join-divider span{font-size:var(--text-xs);color:var(--color-text-faint);white-space:nowrap}
.join-divider::before,.join-divider::after{content:'';flex:1;height:1px;background:var(--color-divider)}
.role-selector{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3);margin-bottom:var(--space-5)}
.role-card{padding:var(--space-4);border:2px solid var(--color-border);border-radius:var(--radius-xl);
  cursor:pointer;text-align:center;transition:all var(--tr)}
.role-card:hover{border-color:var(--color-primary)}
.role-card.selected{border-color:var(--color-primary);background:var(--color-primary-highlight)}
.role-card-icon{font-size:1.8rem;margin-bottom:var(--space-2)}
.role-card-label{font-size:var(--text-sm);font-weight:600;color:var(--color-text)}

/* ── INNER PAGE HEADER ───────────────────────────────────────*/
.inner-page-header{background:var(--color-primary);color:#fff;padding:var(--space-10) 0 var(--space-8)}
.inner-page-header-inner{display:flex;flex-direction:column;gap:var(--space-3)}
.back-btn{display:inline-flex;align-items:center;gap:var(--space-2);color:rgba(255,255,255,0.75);
  font-size:var(--text-sm);font-weight:600;background:rgba(255,255,255,0.12);border:none;
  padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);cursor:pointer;
  width:fit-content;transition:color var(--tr),background var(--tr)}
.back-btn:hover{color:#fff;background:rgba(255,255,255,0.22)}
.inner-page-title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:900;color:#fff}
.inner-page-sub{font-size:var(--text-base);color:rgba(255,255,255,0.8);max-width:60ch}

/* ── CALENDAR ────────────────────────────────────────────────*/
.calendar-controls{display:flex;align-items:center;justify-content:space-between;
  margin-bottom:var(--space-6);gap:var(--space-4)}
.calendar-month-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:900;
  color:var(--color-text);text-align:center;flex:1}
.calendar-legend{display:flex;align-items:center;gap:var(--space-6);margin-bottom:var(--space-4);
  font-size:var(--text-xs);color:var(--color-text-muted)}
.cal-legend-item{display:flex;align-items:center;gap:var(--space-2)}
.cal-legend-available::before{content:'';display:inline-block;width:14px;height:14px;
  border-radius:var(--radius-sm);background:var(--color-primary)}
.cal-legend-today::before{content:'';display:inline-block;width:14px;height:14px;
  border-radius:var(--radius-sm);background:var(--color-accent);opacity:.6}
.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:var(--space-2);margin-bottom:var(--space-6)}
.cal-day-header{text-align:center;font-size:var(--text-xs);font-weight:700;
  color:var(--color-text-faint);padding:var(--space-2);text-transform:uppercase;letter-spacing:.08em}
.cal-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;
  border-radius:var(--radius-md);font-size:var(--text-sm);cursor:pointer;font-weight:500;
  border:1.5px solid transparent;color:var(--color-text-muted);
  transition:all var(--tr)}
.cal-day:hover:not(.cal-empty):not(.cal-past){background:var(--color-primary-highlight);
  color:var(--color-primary);border-color:var(--color-primary)}
.cal-day.cal-available{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}
.cal-day.cal-today{border-color:var(--color-accent);color:var(--color-accent);font-weight:700}
.cal-day.cal-today.cal-available{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}
.cal-day.cal-past{opacity:.35;cursor:default}
.cal-day.cal-empty{cursor:default}
.calendar-actions{display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:var(--space-4);padding-top:var(--space-6);border-top:1px solid var(--color-divider)}
.calendar-selected-count{font-size:var(--text-sm);color:var(--color-text-muted);font-weight:500}
.auth-gate-card{background:var(--color-surface);border:1px solid var(--color-divider);
  border-radius:var(--radius-2xl);padding:var(--space-12);text-align:center;max-width:480px;margin:0 auto}

/* ── DONATE PAGE ─────────────────────────────────────────────*/
.donate-layout{display:grid;grid-template-columns:1fr 1.2fr;gap:var(--space-12);
  padding-top:var(--space-10);padding-bottom:var(--space-20);align-items:start}
.donate-impact-cards{display:flex;flex-direction:column;gap:var(--space-4);margin-bottom:var(--space-8)}
.impact-card{display:flex;align-items:center;gap:var(--space-5);padding:var(--space-5);
  background:var(--color-surface);border:1px solid var(--color-divider);
  border-radius:var(--radius-xl);transition:border-color var(--tr),box-shadow var(--tr)}
.impact-card:hover{border-color:var(--color-accent);box-shadow:var(--shadow-sm)}
.impact-icon{font-size:2rem;flex-shrink:0}
.impact-card strong{display:block;font-family:var(--font-display);font-size:var(--text-lg);font-weight:900;color:var(--color-accent)}
.impact-card p{font-size:var(--text-sm);color:var(--color-text-muted);margin-top:var(--space-1)}
.donate-stats-card{background:var(--color-primary);border-radius:var(--radius-2xl);padding:var(--space-8);
  display:flex;gap:var(--space-8)}
.donate-stat{display:flex;flex-direction:column;gap:var(--space-1)}
.donate-stat-num{font-family:var(--font-display);font-size:var(--text-xl);font-weight:900;color:#fff}
.donate-stat-label{font-size:var(--text-xs);color:rgba(255,255,255,0.65);text-transform:uppercase;letter-spacing:.08em}
.donate-form-card{background:var(--color-surface);border:1px solid var(--color-divider);
  border-radius:var(--radius-2xl);padding:var(--space-8);box-shadow:var(--shadow-md)}
.donate-form-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:900;
  color:var(--color-text);margin-bottom:var(--space-6)}
.amount-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3);margin-bottom:var(--space-5)}
.amount-btn{padding:var(--space-4);border-radius:var(--radius-xl);border:2px solid var(--color-border);
  font-size:var(--text-base);font-weight:700;color:var(--color-text-muted);background:var(--color-bg);
  transition:all var(--tr)}
.amount-btn:hover{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-highlight)}
.amount-btn-active{background:var(--color-accent)!important;color:#fff!important;border-color:var(--color-accent)!important}
.donate-total-display{background:var(--color-accent-highlight);border-radius:var(--radius-lg);
  padding:var(--space-4);text-align:center;font-size:var(--text-base);color:var(--color-text-muted)}
.donate-total-display strong{color:var(--color-accent);font-size:var(--text-lg)}
@media(max-width:860px){.donate-layout{grid-template-columns:1fr}}

/* ── HOST PROJECT FORM ───────────────────────────────────────*/
.host-project-section .container{max-width:720px}

/* ── SUCCESS STATES ──────────────────────────────────────────*/
.success-state{text-align:center;padding:var(--space-10) var(--space-8)}
.success-state .success-icon{font-size:4rem;margin-bottom:var(--space-6)}
.success-state h2{font-family:var(--font-display);font-size:var(--text-xl);font-weight:900;margin-bottom:var(--space-4)}
.success-state p{color:var(--color-text-muted);font-size:var(--text-sm);max-width:38ch;margin:0 auto var(--space-8)}
