/*
Theme Name: TenderHaraka
Theme URI: https://tenderharaka.co.ke
Author: TenderHaraka
Description: Custom theme for TenderHaraka — Kenya's government tender intelligence platform. Provides the landing page, a live tenders board, native articles/blog, and sign-in. Built to be honest by default: sample data is clearly labelled until live data is connected.
Version: 1.0
License: GNU General Public License v2 or later
Text Domain: tenderharaka
*/

:root{
  --ink:#15181d; --ink-2:#1d2127; --ink-3:#272c34;
  --bone:#f4f1ea; --bone-2:#ffffff;
  --amber:#f5a524; --amber-deep:#c97f12;
  --verdant:#1f7a5c; --alert:#e5484d;
  --muted:#9aa4ae; --muted-d:#5b6470; --line:#2c323b;
  --radius:14px; --maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,-apple-system,sans-serif;background:var(--bone);color:var(--ink);line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.display,h1,h2,h3{font-family:'Bricolage Grotesque','Inter',sans-serif;line-height:1.05;letter-spacing:-.02em}
.mono{font-family:'JetBrains Mono',monospace}

/* ---- top bar / nav ---- */
.topbar{position:sticky;top:0;z-index:40;background:rgba(21,24,29,.94);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:flex;align-items:center;gap:10px;color:#fff;font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:21px}
.brand .dot{width:11px;height:11px;border-radius:50%;background:var(--amber);animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(245,165,36,.55)}70%{box-shadow:0 0 0 9px rgba(245,165,36,0)}100%{box-shadow:0 0 0 0 rgba(245,165,36,0)}}
.nav{display:flex;align-items:center;gap:26px;list-style:none}
.nav a{color:var(--muted);font-size:14.5px;font-weight:500}
.nav a:hover,.nav .current-menu-item a{color:#fff}
.nav-cta{display:flex;gap:10px;align-items:center}
.btn{font-family:'Inter',sans-serif;font-weight:600;font-size:14.5px;border:0;cursor:pointer;border-radius:10px;padding:11px 18px;transition:transform .12s,background .15s;display:inline-block;text-align:center}
.btn:active{transform:translateY(1px)}
.btn-amber{background:var(--amber);color:#1a1303}
.btn-amber:hover{background:#ffb53d}
.btn-ghost{background:transparent;color:#fff;border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--muted)}
.btn-ink{background:var(--ink);color:#fff}
.btn-ink:hover{background:#22272f}
.btn-line{background:transparent;border:1px solid var(--ink);color:var(--ink)}
.burger{display:none;background:none;border:0;color:#fff;cursor:pointer;font-size:22px}

.launch-band{background:var(--verdant);color:#eafff6;text-align:center;font-size:13px;padding:8px 16px}
.launch-band b{color:#fff}

/* ---- hero ---- */
.hero{background:var(--ink);color:#fff;padding:70px 0 64px;position:relative;overflow:hidden}
.hero:before{content:"";position:absolute;inset:0;background:radial-gradient(700px 300px at 78% 18%,rgba(245,165,36,.10),transparent 60%);pointer-events:none}
.hero .wrap{display:grid;grid-template-columns:1.05fr 1.15fr;gap:48px;align-items:center;position:relative}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--amber);font-weight:600;margin-bottom:20px}
.eyebrow .tick{width:6px;height:6px;border-radius:50%;background:var(--verdant)}
.hero h1{font-size:clamp(38px,5vw,60px);font-weight:800;margin-bottom:20px}
.hero h1 em{font-style:normal;color:var(--amber)}
.hero p.lede{font-size:18px;color:#cdd4db;max-width:520px;margin-bottom:30px}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:24px}
.hero-cta .btn{padding:14px 24px;font-size:15.5px}
.hero-trust{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:9px}
.hero-trust b{color:#fff;font-weight:600}

/* ---- board ---- */
.board{background:var(--ink-2);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:0 30px 60px -25px rgba(0,0,0,.6)}
.board-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:linear-gradient(180deg,#21262e,#1a1f26);border-bottom:1px solid var(--line)}
.board-head .t{display:flex;align-items:center;gap:10px;font-family:'JetBrains Mono',monospace;font-size:12.5px;letter-spacing:.08em;color:#cdd4db;text-transform:uppercase}
.live-dot{width:8px;height:8px;border-radius:50%;background:var(--amber);animation:blink 1.4s steps(1) infinite}
@keyframes blink{50%{opacity:.25}}
.board-head .clock{font-family:'JetBrains Mono',monospace;font-size:12.5px;color:var(--amber)}
.brow{display:grid;grid-template-columns:1fr auto;gap:12px;padding:14px 18px;border-bottom:1px solid rgba(44,50,59,.6);align-items:center}
.brow:last-child{border-bottom:0}
.brow .ttl{font-size:14.5px;font-weight:600;color:#eef1f4;margin-bottom:6px;line-height:1.25}
.brow .meta{display:flex;gap:7px;flex-wrap:wrap;align-items:center}
.pill{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:700;padding:3px 8px;border-radius:6px;text-transform:uppercase}
.pill.open{background:rgba(31,122,92,.18);color:#54c89e;border:1px solid rgba(31,122,92,.4)}
.pill.agpo{background:rgba(245,165,36,.14);color:var(--amber);border:1px solid rgba(245,165,36,.35)}
.pill.county{background:rgba(154,164,174,.12);color:#b8c0c9;border:1px solid var(--line)}
.pill.ref{background:transparent;color:var(--muted-d);border:1px solid var(--line)}
.countdown{font-family:'JetBrains Mono',monospace;font-weight:700;font-size:15px;text-align:right;white-space:nowrap;color:#d7dde3}
.countdown small{display:block;font-size:9.5px;font-weight:500;color:var(--muted-d);text-transform:uppercase;margin-top:2px}
.brow.soon .countdown{color:var(--alert)}
.brow.soon{box-shadow:inset 3px 0 0 var(--alert)}
.board-foot{padding:12px 18px;text-align:center;font-size:12.5px;color:var(--muted);background:#1a1f26}
.board-foot b{color:var(--amber);font-weight:600}
.demo-tag{display:inline-block;font-family:'JetBrains Mono',monospace;font-size:10px;text-transform:uppercase;color:var(--muted);border:1px dashed var(--muted-d);border-radius:6px;padding:2px 8px;margin-left:8px}

/* ---- sections ---- */
.section{padding:84px 0}
.section.bone{background:var(--bone)}
.section.bone-2{background:var(--bone-2)}
.section.ink-sec{background:var(--ink);color:#fff}
.shead{max-width:680px;margin-bottom:48px}
.shead .eyebrow{color:var(--amber-deep)}
.section.ink-sec .shead .eyebrow{color:var(--amber)}
.shead h2{font-size:clamp(28px,3.6vw,42px);font-weight:700;margin-bottom:14px}
.section.ink-sec .shead h2{color:#fff}
.shead p{font-size:17px;color:var(--muted-d)}
.section.ink-sec .shead p{color:#cdd4db}

.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.card{background:var(--bone-2);border:1px solid #e7e2d6;border-radius:var(--radius);padding:28px}
.section.bone-2 .card{background:var(--bone)}
.card .ic{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;background:var(--ink);color:var(--amber);font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:19px;margin-bottom:16px}
.card h3{font-size:19px;font-weight:700;margin-bottom:8px}
.card p{font-size:15px;color:var(--muted-d)}
.card .vs{font-family:'JetBrains Mono',monospace;font-size:11.5px;color:var(--amber-deep);margin-top:12px;padding-top:12px;border-top:1px dashed #d9d3c5}

.steps{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid #e7e2d6;border-radius:var(--radius);overflow:hidden;background:var(--bone-2)}
.step{padding:32px 28px;border-right:1px solid #e7e2d6}
.step:last-child{border-right:0}
.step .n{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--amber-deep);letter-spacing:.1em;margin-bottom:14px}
.step h3{font-size:20px;font-weight:700;margin-bottom:8px}
.step p{font-size:15px;color:var(--muted-d)}

/* ---- facts ---- */
.facts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.fact{background:var(--ink-2);border:1px solid var(--line);border-radius:var(--radius);padding:28px}
.fact .big{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:42px;color:var(--amber);line-height:1;margin-bottom:8px}
.fact p{font-size:14px;color:var(--muted)}
.fact p b{color:#dfe4ea}
.fact .src{display:block;font-family:'JetBrains Mono',monospace;font-size:10.5px;color:var(--muted-d);margin-top:10px}

/* ---- founding ---- */
.founding-box{background:var(--ink);color:#fff;border-radius:var(--radius);padding:48px 44px;display:grid;grid-template-columns:1.3fr 1fr;gap:40px;align-items:center;position:relative;overflow:hidden}
.founding-box:before{content:"";position:absolute;inset:0;background:radial-gradient(500px 240px at 85% 20%,rgba(245,165,36,.12),transparent 60%);pointer-events:none}
.founding-box h2{font-size:clamp(26px,3.4vw,40px);font-weight:800;margin-bottom:14px}
.founding-box h2 em{font-style:normal;color:var(--amber)}
.founding-box p{color:#cdd4db;font-size:16px;margin-bottom:10px}
.founding-list{list-style:none;margin-top:14px}
.founding-list li{display:flex;gap:10px;padding:9px 0;font-size:15px;color:#dfe4ea}
.founding-list li:before{content:"✓";color:var(--verdant);font-weight:700}
.founding-form{background:var(--ink-2);border:1px solid var(--line);border-radius:12px;padding:26px}
.founding-form h3{color:#fff;font-size:18px;margin-bottom:6px}
.founding-form .small{font-size:12.5px;color:var(--muted);margin-bottom:16px}
.f-input{width:100%;background:var(--ink);border:1px solid var(--line);border-radius:9px;padding:12px 13px;color:#fff;font-family:'Inter',sans-serif;font-size:14px;outline:none;margin-bottom:10px}
.f-input:focus{border-color:var(--amber)}
.f-note{font-size:11.5px;color:var(--muted-d);margin-top:10px;line-height:1.5}

/* ---- pricing ---- */
.prices{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.price{background:var(--bone-2);border:1px solid #e7e2d6;border-radius:var(--radius);padding:30px 26px;position:relative}
.price.feat{border:2px solid var(--ink);box-shadow:0 24px 50px -28px rgba(0,0,0,.4)}
.price .tag{position:absolute;top:-12px;right:22px;background:var(--amber);color:#1a1303;font-family:'JetBrains Mono',monospace;font-size:10.5px;font-weight:700;padding:4px 10px;border-radius:6px;text-transform:uppercase}
.price .pname{font-family:'JetBrains Mono',monospace;font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-d);margin-bottom:12px}
.price .amt{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:40px;line-height:1;margin-bottom:4px}
.price .amt span{font-family:'Inter',sans-serif;font-size:15px;font-weight:500;color:var(--muted-d)}
.price .per{font-size:13px;color:var(--muted-d);margin-bottom:20px}
.price ul{list-style:none;margin-bottom:24px}
.price li{font-size:14.5px;padding:8px 0;display:flex;gap:10px;color:#3a4048}
.price li:before{content:"✓";color:var(--verdant);font-weight:700}
.price li.off{color:#aeb4bb}
.price li.off:before{content:"–";color:#cfd3d8}
.price .btn{width:100%}
.mpesa{text-align:center;font-size:13px;color:var(--muted-d);margin-top:22px}
.mpesa b{color:var(--verdant)}

/* ---- tenders page filters ---- */
.tp-head{background:var(--ink);color:#fff;padding:48px 0 36px}
.tp-head h1{font-size:clamp(30px,4vw,46px);font-weight:800;margin-bottom:10px}
.tp-head h1 em{font-style:normal;color:var(--amber)}
.tp-head p{color:#cdd4db;font-size:16px}
.tp-tools{display:flex;gap:10px;flex-wrap:wrap;margin:22px 0}
.tp-input{flex:1;min-width:200px;background:var(--ink-2);border:1px solid var(--line);border-radius:10px;padding:12px 14px;color:#fff;font-family:'Inter',sans-serif;font-size:14px;outline:none}
.tp-input:focus{border-color:var(--amber)}
.tp-chip{background:var(--ink-2);border:1px solid var(--line);color:#cdd4db;font-size:13px;padding:9px 14px;border-radius:50px;cursor:pointer}
.tp-chip.active,.tp-chip:hover{border-color:var(--amber);color:#fff}
.tp-list{padding:40px 0}
.tp-card{background:var(--bone-2);border:1px solid #e7e2d6;border-left:4px solid var(--amber);border-radius:0 12px 12px 0;padding:20px 22px;margin-bottom:12px}
.tp-card h3{font-size:17px;font-weight:700;margin-bottom:6px}
.tp-card .row{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:8px}
.tp-tag{font-family:'JetBrains Mono',monospace;font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:6px;text-transform:uppercase}
.tp-tag.agpo{background:#fbeeda;color:#8a5a0c}
.tp-tag.county{background:#eef0f2;color:#4b5560}
.tp-tag.open{background:#e6f4ee;color:#176a4f}
.tp-card .sum{font-size:14px;color:var(--muted-d);margin-bottom:10px}
.tp-card .foot{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--muted-d)}
.tp-card .dl{font-weight:600;color:var(--alert)}

/* ---- blog / articles ---- */
.page-head{background:var(--ink);color:#fff;padding:54px 0 40px;text-align:center}
.page-head h1{font-size:clamp(30px,4vw,46px);font-weight:800}
.page-head p{color:#cdd4db;margin-top:10px}
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;padding:54px 0}
.post-card{background:var(--bone-2);border:1px solid #e7e2d6;border-radius:var(--radius);overflow:hidden;transition:transform .15s,box-shadow .15s}
.post-card:hover{transform:translateY(-3px);box-shadow:0 18px 40px -22px rgba(0,0,0,.3)}
.post-card .thumb{height:170px;background:linear-gradient(135deg,#1d2127,#272c34);display:grid;place-items:center;font-size:40px;color:var(--amber);overflow:hidden}
.post-card .thumb img{width:100%;height:100%;object-fit:cover}
.post-card .pb{padding:22px}
.post-card .cat{font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--amber-deep);margin-bottom:8px}
.post-card h2{font-size:18px;font-weight:700;margin-bottom:8px;line-height:1.3}
.post-card .ex{font-size:13.5px;color:var(--muted-d)}
.post-card .date{font-size:11.5px;color:var(--muted);margin-top:12px}

.article{max-width:740px;margin:0 auto;padding:54px 22px}
.article h1{font-size:clamp(28px,3.6vw,40px);font-weight:800;margin-bottom:14px;line-height:1.1}
.article .meta{font-size:13px;color:var(--muted-d);margin-bottom:30px;padding-bottom:20px;border-bottom:1px solid #e7e2d6}
.article p{font-size:17px;line-height:1.8;color:#2a2f36;margin-bottom:20px}
.article h2{font-size:26px;font-weight:700;margin:36px 0 14px}
.article h3{font-size:21px;font-weight:700;margin:28px 0 10px}
.article ul,.article ol{margin:0 0 20px 22px}
.article li{font-size:17px;line-height:1.8;margin-bottom:8px}
.article a{color:var(--amber-deep);text-decoration:underline}
.article img{border-radius:10px;margin:20px 0}
.article blockquote{border-left:4px solid var(--amber);padding-left:18px;font-style:italic;color:var(--muted-d);margin:0 0 20px}

/* ---- cta band + footer ---- */
.cta-band{background:var(--ink);color:#fff;padding:64px 0;text-align:center}
.cta-band h2{font-size:clamp(28px,4vw,44px);font-weight:800;margin-bottom:16px}
.cta-band h2 em{font-style:normal;color:var(--amber)}
.cta-band p{color:#cdd4db;max-width:520px;margin:0 auto 28px;font-size:17px}
footer.site{background:#0f1216;color:var(--muted);padding:54px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px;padding-bottom:34px;border-bottom:1px solid var(--line)}
.foot-grid h4{color:#fff;font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:15px;margin-bottom:14px}
.foot-grid a{display:block;font-size:14px;color:var(--muted);padding:5px 0}
.foot-grid a:hover{color:var(--amber)}
.foot-brand p{font-size:13.5px;max-width:260px;line-height:1.6;margin-top:12px}
.foot-bot{display:flex;justify-content:space-between;align-items:center;padding-top:22px;font-size:12.5px;flex-wrap:wrap;gap:10px}

/* ---- ad slot ---- */
.adwrap{max-width:var(--maxw);margin:0 auto;padding:26px 22px}
.adslot{border:1px dashed #cfc9ba;border-radius:12px;min-height:110px;display:grid;place-items:center;color:#b3ac9b;font-family:'JetBrains Mono',monospace;font-size:12px}

/* ---- floating assistant ---- */
.fab{position:fixed;right:22px;bottom:22px;z-index:60;background:var(--amber);color:#1a1303;border:0;border-radius:50px;padding:14px 20px;font-family:'Inter',sans-serif;font-weight:600;font-size:15px;cursor:pointer;box-shadow:0 14px 30px -8px rgba(245,165,36,.6);display:flex;align-items:center;gap:9px}
.fab .pd{width:9px;height:9px;border-radius:50%;background:var(--verdant)}
.panel{position:fixed;right:22px;bottom:22px;z-index:61;width:min(380px,calc(100vw - 32px));height:min(560px,calc(100vh - 60px));background:var(--ink-2);border:1px solid var(--line);border-radius:18px;overflow:hidden;display:none;flex-direction:column;box-shadow:0 40px 80px -20px rgba(0,0,0,.7)}
.panel.open{display:flex}
.p-head{display:flex;align-items:center;gap:11px;padding:15px 17px;background:#1a1f26;border-bottom:1px solid var(--line)}
.p-head .av{width:34px;height:34px;border-radius:9px;background:var(--amber);color:#1a1303;display:grid;place-items:center;font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:17px}
.p-head .who b{color:#fff;font-size:15px;display:block;line-height:1.1}
.p-head .who span{color:var(--verdant);font-size:11px;font-family:'JetBrains Mono',monospace}
.p-head .x{margin-left:auto;background:none;border:0;color:var(--muted);font-size:22px;cursor:pointer}
.p-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:11px}
.bub{max-width:88%;padding:11px 14px;border-radius:13px;font-size:14px;line-height:1.45}
.bub.u{align-self:flex-end;background:var(--amber);color:#1a1303;border-bottom-right-radius:4px}
.bub.a{align-self:flex-start;background:var(--ink-3);color:#e8ecf0;border-bottom-left-radius:4px}
.chips{display:flex;flex-wrap:wrap;gap:7px;padding:0 16px 12px}
.chip{background:var(--ink-3);border:1px solid var(--line);color:#cdd4db;font-size:12.5px;padding:7px 12px;border-radius:50px;cursor:pointer}
.chip:hover{border-color:var(--amber);color:#fff}
.p-input{display:flex;gap:8px;padding:13px 14px;border-top:1px solid var(--line);background:#1a1f26}
.p-input input{flex:1;background:var(--ink);border:1px solid var(--line);border-radius:10px;padding:11px 13px;color:#fff;font-size:14px;outline:none}
.p-input button{background:var(--amber);border:0;color:#1a1303;border-radius:10px;padding:0 16px;font-weight:600;cursor:pointer}

/* ---- responsive ---- */
@media(max-width:920px){
  .hero .wrap{grid-template-columns:1fr;gap:36px}
  .grid-2,.grid-3,.prices,.facts-grid,.post-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .step{border-right:0;border-bottom:1px solid #e7e2d6}
  .founding-box{grid-template-columns:1fr;padding:34px 26px}
  .foot-grid{grid-template-columns:1fr 1fr}
  .nav{display:none}
  .burger{display:block}
}
@media(max-width:520px){
  .hero{padding:48px 0}.section{padding:60px 0}
  .foot-grid{grid-template-columns:1fr}.hero-cta .btn{flex:1}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
