/* GIG Zimbabwe website — kit layout styles (loads after colors_and_type.css) */
*{box-sizing:border-box}
html,body{margin:0}
body{font-family:var(--font-sans);color:var(--fg-1);background:var(--paper);-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font-family:inherit}

.wrap{max-width:1200px;margin:0 auto;padding:0 28px}
.section{padding:clamp(56px,8vw,112px) 0}

/* ---- buttons ---- */
.btn{font-family:var(--font-sans);font-weight:700;font-size:15px;border:0;cursor:pointer;
  padding:13px 24px;border-radius:var(--r-pill);display:inline-flex;align-items:center;gap:9px;
  transition:transform var(--dur-fast) var(--ease-soft),background var(--dur) var(--ease-soft),box-shadow var(--dur) var(--ease-soft);
  text-decoration:none;line-height:1;white-space:nowrap}
.btn .ph-ic{font-size:18px}
.btn-primary{background:var(--brand);color:#fff;box-shadow:var(--shadow-glow)}
.btn-primary:hover{background:var(--brand-strong)}
.btn-primary:active{transform:scale(.98);box-shadow:var(--shadow-sm)}
.btn-ghost{background:transparent;color:var(--brand-strong);box-shadow:inset 0 0 0 1.5px var(--grail-lavender-300)}
.btn-ghost:hover{background:var(--grail-lavender-100)}
.btn-ghost:active{transform:scale(.98)}
.btn-light{background:#fff;color:var(--brand-strong)}
.btn-light:hover{background:var(--grail-lavender-100)}
.btn-text{background:none;color:var(--brand);font-weight:700;padding:0;display:inline-flex;align-items:center;gap:6px;cursor:pointer;border:0}
.btn-text:hover{color:var(--brand-strong)}

/* ---- eyebrow ---- */
.eyebrow{font-family:var(--font-sans);font-weight:800;font-size:13px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--brand);display:inline-flex;align-items:center;gap:9px;margin:0 0 16px}
.eyebrow.gold{color:var(--grail-gold)}
.eyebrow .tick{width:22px;height:2px;background:currentColor;border-radius:2px;opacity:.6}

.title{font-family:var(--font-display);font-weight:700;letter-spacing:-.02em;line-height:1.06;color:var(--fg-1);margin:0}
.lead{font-size:var(--text-md);line-height:1.62;color:var(--fg-2);margin:14px 0 0}

/* ---- tags ---- */
.tag{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:700;padding:7px 15px;border-radius:var(--r-pill)}
.tag .ph-ic{font-size:15px}
.tag-brand{background:var(--grail-lavender-100);color:var(--brand-strong)}
.tag-leaf{background:var(--grail-leaf-soft);color:#33572f}
.tag-gold{background:var(--grail-gold-soft);color:#86610f}

/* ---- header ---- */
.hdr{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.82);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line)}
.hdr-in{display:flex;align-items:center;gap:24px;height:78px}
.brand{display:flex;align-items:center;gap:12px;cursor:pointer}
.brand img{height:50px;width:auto}
.brand .wm{display:flex;flex-direction:column;line-height:1}
.brand .wm b{font-family:var(--font-display);font-weight:700;font-size:21px;color:var(--brand-strong);letter-spacing:-.01em}
.brand .wm span{font-size:10.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-3);margin-top:3px}
.nav{display:flex;gap:4px;margin-left:auto}
.nav a{font-weight:600;font-size:15px;color:var(--ink-700);padding:9px 15px;border-radius:var(--r-pill);cursor:pointer;transition:background var(--dur),color var(--dur)}
.nav a:hover{background:var(--grail-lavender-100);color:var(--brand-strong)}
.nav a.active{color:var(--brand-strong);background:var(--grail-lavender-100)}
.hdr .btn{padding:10px 18px;font-size:14px}
.menu-btn{display:none;margin-left:auto;background:none;border:0;font-size:28px;color:var(--brand-strong);cursor:pointer}

/* ---- hero ---- */
.hero{position:relative;overflow:hidden;background:
  radial-gradient(120% 90% at 80% -10%, var(--grail-lavender-100) 0%, rgba(248,242,249,0) 60%),
  linear-gradient(180deg,#fff 0%, var(--paper-2) 100%)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;
  padding:clamp(48px,7vw,96px) 0 clamp(56px,8vw,104px)}
.hero h1{font-family:var(--font-display);font-weight:700;font-size:var(--text-3xl);line-height:1.04;letter-spacing:-.025em;margin:18px 0 0}
.hero .accent{color:var(--brand)}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}
.hero-art{position:relative;display:grid;place-items:center;min-height:380px}
.hero-art .glow{position:absolute;inset:0;background:radial-gradient(60% 60% at 50% 45%, rgba(190,132,192,.34),transparent 70%)}
.hero-art img.chalice{position:relative;width:min(100%,420px);filter:drop-shadow(0 24px 48px rgba(122,46,122,.28))}
.hero-verse{position:relative;margin-top:18px;font-family:var(--font-serif);font-style:italic;font-weight:500;
  font-size:17px;color:var(--brand-strong);text-align:center;max-width:340px}
.hero-verse cite{display:block;font-family:var(--font-sans);font-style:normal;font-weight:700;font-size:11px;
  letter-spacing:.08em;text-transform:uppercase;color:var(--fg-3);margin-top:8px}

/* ---- stat strip ---- */
.stats{background:var(--grail-plum-900);color:#fff;position:relative;overflow:hidden}
.stats .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;padding:46px 28px;position:relative;z-index:1}
.stat{text-align:center}
.stat b{display:block;font-family:var(--font-display);font-weight:700;font-size:clamp(2rem,3.4vw,2.9rem);color:#fff;line-height:1}
.stat span{display:block;font-size:13px;color:var(--fg-on-dark-2);margin-top:8px;font-weight:600;letter-spacing:.02em}
.stats .wm{position:absolute;right:-90px;bottom:-150px;width:420px;opacity:.5;z-index:0}

/* ---- pillars / cards ---- */
.head-block{max-width:680px}
.head-block.center{margin:0 auto;text-align:center}
.cards{display:grid;gap:22px;margin-top:46px}
.cards.c2{grid-template-columns:repeat(2,1fr)}
.cards.c3{grid-template-columns:repeat(3,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--shadow-md);
  padding:28px;transition:transform var(--dur) var(--ease-soft),box-shadow var(--dur) var(--ease-soft)}
.card.feature{border-radius:var(--r-petal)}
.card.lift:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.ic-tile{width:52px;height:52px;border-radius:15px;display:grid;place-items:center;font-size:27px;margin-bottom:18px}
.ic-brand{background:var(--grail-lavender-100);color:var(--brand)}
.ic-leaf{background:var(--grail-leaf-soft);color:#3f6b3b}
.ic-gold{background:var(--grail-gold-soft);color:#8a6411}
.card h3{font-family:var(--font-sans);font-weight:800;font-size:19px;margin:0 0 9px;color:var(--fg-1)}
.card p{font-size:14.5px;line-height:1.58;color:var(--fg-2);margin:0}

/* ---- creed / scripture band ---- */
.creed{background:var(--paper-2)}
.creed-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:54px;align-items:center}
.creed blockquote{margin:0;font-family:var(--font-display);font-weight:500;font-size:clamp(1.4rem,2.4vw,2rem);
  line-height:1.34;color:var(--brand-strong);letter-spacing:-.01em}
.creed .embraces{list-style:none;padding:0;margin:0;display:grid;gap:2px}
.creed .embraces li{display:flex;gap:14px;align-items:flex-start;padding:15px 0;border-bottom:1px solid var(--line)}
.creed .embraces li:last-child{border-bottom:0}
.creed .embraces .n{font-family:var(--font-display);font-weight:700;color:var(--grail-orchid-300);font-size:18px;min-width:26px}
.creed .embraces p{margin:0;font-weight:600;font-size:15.5px;color:var(--ink-700)}

/* ---- activities timeline ---- */
.tl{margin-top:46px;display:grid;gap:0}
.tl-item{display:grid;grid-template-columns:150px 1fr;gap:28px;padding:24px 0;border-top:1px solid var(--line);align-items:start}
.tl-item:last-child{border-bottom:1px solid var(--line)}
.tl-year{font-family:var(--font-display);font-weight:700;font-size:20px;color:var(--brand)}
.tl-item h4{margin:0 0 6px;font-size:17px;font-weight:800}
.tl-item p{margin:0;color:var(--fg-2);font-size:14.5px;line-height:1.55}

/* ---- get involved / form ---- */
.join{background:var(--grail-plum-900);color:#fff;position:relative;overflow:hidden}
.join-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center;position:relative;z-index:1}
.join h2{font-family:var(--font-display);font-weight:700;font-size:var(--text-2xl);margin:14px 0 0;color:#fff;line-height:1.08}
.join p.l{color:var(--fg-on-dark-2);font-size:16px;line-height:1.6;margin-top:16px}
.join .wm{position:absolute;left:-120px;top:-80px;width:380px;opacity:.5;z-index:0}
.form-card{background:#fff;border-radius:var(--r-lg);padding:30px;box-shadow:var(--shadow-lg)}
.form-card h3{margin:0 0 4px;font-family:var(--font-display);font-weight:700;font-size:21px;color:var(--fg-1)}
.form-card .sub{margin:0 0 20px;font-size:13.5px;color:var(--fg-2)}
.field{margin-bottom:15px}
.field label{display:block;font-size:12.5px;font-weight:700;color:var(--ink-700);margin-bottom:6px}
.field input,.field select{width:100%;font-family:var(--font-sans);font-size:14.5px;padding:12px 14px;
  border:1.5px solid var(--line-strong);border-radius:var(--r-sm);background:#fff;color:var(--fg-1);outline:none;transition:border var(--dur),box-shadow var(--dur)}
.field select{appearance:none;-webkit-appearance:none;padding-right:42px;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%239B4A9B' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 15px center}
.field textarea{width:100%;box-sizing:border-box;font-family:var(--font-sans);font-size:14.5px;padding:12px 14px;
  border:1.5px solid var(--line-strong);border-radius:var(--r-sm);background:#fff;color:var(--fg-1);outline:none;
  resize:vertical;min-height:96px;line-height:1.5;transition:border var(--dur),box-shadow var(--dur)}
.field textarea::placeholder{color:var(--ink-300)}
.field textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(190,132,192,.3)}
.field input:focus,.field select:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(190,132,192,.3)}
.form-ok{text-align:center;padding:18px 6px}
.form-ok .ring{width:62px;height:62px;border-radius:50%;background:var(--grail-leaf-soft);color:var(--ok);
  display:grid;place-items:center;font-size:34px;margin:0 auto 14px}
.form-ok h3{margin:0 0 6px}
.form-ok p{color:var(--fg-2);font-size:14px;margin:0}

/* ---- newsletter ---- */
.news{display:flex;gap:12px;max-width:440px;margin-top:18px}
.news input{flex:1;font-family:var(--font-sans);font-size:14.5px;padding:13px 16px;border:1.5px solid rgba(255,255,255,.3);
  border-radius:var(--r-pill);background:rgba(255,255,255,.1);color:#fff;outline:none}
.news input::placeholder{color:rgba(255,255,255,.6)}
.news input:focus{border-color:#fff}

/* ---- footer ---- */
.ft{background:#2a132b;color:var(--fg-on-dark-2);position:relative;overflow:hidden}
.ft-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;padding:64px 0 48px;position:relative;z-index:1}
.ft .wm{position:absolute;right:-60px;top:30px;width:300px;opacity:.5;z-index:0}
.ft-brand img{height:54px;margin-bottom:16px}
.ft-brand p{font-size:14px;line-height:1.6;max-width:280px;margin:0}
.ft h5{font-family:var(--font-sans);font-weight:800;font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:#fff;margin:0 0 16px}
.ft ul{list-style:none;padding:0;margin:0;display:grid;gap:11px}
.ft ul a{font-size:14px;color:var(--fg-on-dark-2);cursor:pointer}
.ft ul a:hover{color:#fff}
.ft-bottom{border-top:1px solid rgba(255,255,255,.12);padding:22px 0;display:flex;justify-content:space-between;
  gap:14px;flex-wrap:wrap;font-size:12.5px;color:rgba(255,255,255,.6);position:relative;z-index:1}
.ft-social{display:flex;gap:10px}
.ft-social a{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.1);color:#fff;font-size:19px;cursor:pointer;transition:background var(--dur)}
.ft-social a:hover{background:var(--brand)}

/* ---- view transition (transform-only; never hides content) ---- */
.view{animation:rise var(--dur-slow) var(--ease-rise)}
@keyframes rise{from{transform:translateY(10px)}to{transform:none}}
@media (prefers-reduced-motion: reduce){.view{animation:none}}

/* ---- responsive ---- */
@media(max-width:900px){
  .nav{display:none}
  .menu-btn{display:block}
  .hero-grid,.creed-grid,.join-grid{grid-template-columns:1fr;gap:36px}
  .hero-art{min-height:280px}
  .cards.c3,.cards.c2{grid-template-columns:1fr}
  .stats .wrap{grid-template-columns:repeat(2,1fr);gap:28px}
  .ft-top{grid-template-columns:1fr 1fr}
  .tl-item{grid-template-columns:70px 1fr;gap:16px}
}
