/* LinkUp Kenya — Design System v4 */
:root{
  --primary:#E8003D;--primary-hover:#c90034;--primary-soft:#FFE8EE;--accent:#FF6B9D;
  --bg:#FAFAFA;--surface:#FFFFFF;--surface-2:#F5F5F7;--border:#E5E5E9;
  --text:#0A0A0B;--text-muted:#6B6B73;--text-soft:#9B9BA3;
  --success:#16A34A;--warning:#F59E0B;--danger:#DC2626;
  --r-sm:8px;--r-md:12px;--r-lg:16px;--r-xl:24px;--r-full:999px;
  --s-1:4px;--s-2:8px;--s-3:12px;--s-4:16px;--s-5:20px;--s-6:24px;--s-8:32px;--s-10:40px;--s-12:48px;--s-16:64px;
  --shadow-sm:0 1px 2px rgba(0,0,0,.04);
  --shadow-md:0 4px 12px rgba(0,0,0,.06),0 1px 3px rgba(0,0,0,.04);
  --shadow-lg:0 12px 32px rgba(0,0,0,.08),0 4px 8px rgba(0,0,0,.04);
  --shadow-primary:0 8px 24px rgba(232,0,61,.25);
  --font-head:'Plus Jakarta Sans',system-ui,sans-serif;
  --font-body:'Inter',system-ui,sans-serif;
}
[data-theme="dark"]{--bg:#0A0A0B;--surface:#15151A;--surface-2:#1C1C22;--border:#27272F;--text:#FAFAFA;--text-muted:#A1A1AA;--text-soft:#71717A;--primary-soft:#2a0a14;}
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--font-body);background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased;min-height:100vh;padding-bottom:env(safe-area-inset-bottom)}
h1,h2,h3,h4{font-family:var(--font-head);margin:0 0 var(--s-3);letter-spacing:-.02em;color:var(--text)}
h1{font-size:clamp(2rem,5vw,2.75rem);font-weight:800;line-height:1.1}
h2{font-size:clamp(1.5rem,3vw,1.875rem);font-weight:700}
h3{font-size:1.25rem;font-weight:600}
p{margin:0 0 var(--s-3);color:var(--text-muted)}
a{color:var(--primary);text-decoration:none}a:hover{color:var(--primary-hover)}
img{max-width:100%;display:block}
:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:var(--r-sm)}
@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;transition-duration:.01ms!important}}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--s-2);min-height:44px;padding:0 var(--s-5);border:1px solid transparent;border-radius:var(--r-md);font:600 .95rem var(--font-body);cursor:pointer;transition:transform .15s,box-shadow .15s,background .15s;text-decoration:none;white-space:nowrap}
.btn-sm{min-height:36px;padding:0 var(--s-4);font-size:.875rem}
.btn-lg{min-height:52px;padding:0 var(--s-6);font-size:1rem}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-hover);color:#fff;box-shadow:var(--shadow-primary);transform:translateY(-1px)}
.btn-secondary{background:var(--surface);color:var(--text);border-color:var(--border)}
.btn-secondary:hover{background:var(--surface-2);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--text)}
.btn-ghost:hover{background:var(--surface-2)}
.btn-block{width:100%}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}

/* Navigation */
.nav{position:sticky;top:0;z-index:40;background:color-mix(in srgb,var(--surface) 92%,transparent);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}
.nav-inner{max-width:1280px;margin:0 auto;padding:var(--s-3) var(--s-4);display:flex;align-items:center;gap:var(--s-4)}
.logo{font-family:var(--font-head);font-weight:800;font-size:1.5rem;color:var(--text)}
.logo span{color:var(--primary)}
.nav-links{display:none;gap:var(--s-5);margin-left:var(--s-6);flex:1}
.nav-links a{color:var(--text-muted);font-weight:500}
.nav-links a:hover{color:var(--text)}
.nav-actions{margin-left:auto;display:flex;gap:var(--s-2);align-items:center}
.icon-btn{background:transparent;border:none;width:40px;height:40px;border-radius:var(--r-full);cursor:pointer;font-size:1.125rem;display:inline-flex;align-items:center;justify-content:center;color:var(--text);position:relative}
.icon-btn:hover{background:var(--surface-2)}
.badge{position:absolute;top:4px;right:4px;background:var(--primary);color:#fff;font-size:.65rem;font-weight:700;min-width:16px;height:16px;padding:0 4px;border-radius:var(--r-full);display:flex;align-items:center;justify-content:center}
@media(min-width:768px){.nav-links{display:flex}}

/* Main / container */
.main{max-width:1280px;margin:0 auto;padding:var(--s-6) var(--s-4);min-height:calc(100vh - 140px)}
.container{max-width:1120px;margin:0 auto}
.container-sm{max-width:480px;margin:0 auto}

/* Cards */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--s-5);box-shadow:var(--shadow-md);transition:transform .15s,box-shadow .15s}
.card-interactive:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.card-pad{padding:var(--s-6)}

/* Forms */
.field{margin-bottom:var(--s-4)}
.field label{display:block;font-weight:600;font-size:.875rem;color:var(--text);margin-bottom:var(--s-2)}
.input,.select,.textarea{width:100%;min-height:44px;padding:0 var(--s-4);border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);color:var(--text);font:400 .95rem var(--font-body);transition:border-color .15s,box-shadow .15s}
.textarea{padding:var(--s-3) var(--s-4);min-height:120px;resize:vertical;line-height:1.5}
.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(232,0,61,.15)}
.help{font-size:.8rem;color:var(--text-soft);margin-top:var(--s-1)}
.field-error{color:var(--danger);font-size:.8rem;margin-top:var(--s-1)}

/* Hero */
.hero{padding:var(--s-16) var(--s-4);text-align:center;background:radial-gradient(ellipse at top,rgba(232,0,61,.08),transparent 60%)}
.hero h1{max-width:800px;margin:0 auto var(--s-4)}
.hero p{max-width:600px;margin:0 auto var(--s-6);font-size:1.125rem}
.hero-ctas{display:flex;gap:var(--s-3);justify-content:center;flex-wrap:wrap}

/* Profile grid */
.grid{display:grid;gap:var(--s-4);grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}
@media(min-width:768px){.grid{gap:var(--s-5);grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}}
.profile-card{background:var(--surface);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-md);transition:transform .15s,box-shadow .15s;position:relative}
.profile-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.profile-card .photo{aspect-ratio:3/4;object-fit:cover;width:100%}
.profile-card .meta{padding:var(--s-3)}
.profile-card .name{font-weight:700;color:var(--text);margin:0}
.profile-card .sub{font-size:.8rem;color:var(--text-muted);margin-top:2px}
.profile-card.verified .name::after{content:"✓";margin-left:4px;color:var(--primary)}
.online-dot{position:absolute;top:10px;right:10px;width:10px;height:10px;border-radius:50%;background:var(--success);box-shadow:0 0 0 2px var(--surface)}

/* Footer */
.footer{border-top:1px solid var(--border);background:var(--surface);padding:var(--s-8) var(--s-4) calc(var(--s-8) + 64px)}
.footer-inner{max-width:1280px;margin:0 auto;display:grid;gap:var(--s-4);text-align:center}
.footer-nav{display:flex;gap:var(--s-4);justify-content:center;flex-wrap:wrap}
.footer-nav a{color:var(--text-muted);font-size:.9rem}
.footer-copy{color:var(--text-soft);font-size:.85rem}
@media(min-width:768px){.footer{padding-bottom:var(--s-8)}}

/* Mobile bottom tabs */
.bottom-tabs{position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);display:flex;z-index:50;padding-bottom:env(safe-area-inset-bottom);box-shadow:0 -4px 12px rgba(0,0,0,.05)}
.bottom-tabs a{flex:1;padding:var(--s-2) 0;display:flex;flex-direction:column;align-items:center;gap:2px;color:var(--text-muted);font-size:.7rem;font-weight:600;min-height:56px;justify-content:center}
.bottom-tabs a span{font-size:1.3rem}
.bottom-tabs a:hover,.bottom-tabs a.active{color:var(--primary)}
@media(min-width:768px){.bottom-tabs{display:none}}

/* FAB */
.fab-wrap{position:fixed;right:var(--s-4);bottom:calc(72px + env(safe-area-inset-bottom));z-index:45}
@media(min-width:768px){.fab-wrap{bottom:var(--s-6)}}
.fab{width:56px;height:56px;border-radius:var(--r-full);background:var(--primary);color:#fff;border:none;font-size:1.5rem;font-weight:300;box-shadow:var(--shadow-primary);cursor:pointer;transition:transform .15s}
.fab:hover,.fab.open{transform:rotate(45deg) scale(1.05)}
.fab-menu{position:absolute;bottom:68px;right:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:var(--s-2);min-width:200px;display:flex;flex-direction:column;animation:fabIn .2s ease-out}
.fab-menu[hidden]{display:none}
.fab-menu a{padding:var(--s-3);border-radius:var(--r-sm);color:var(--text);font-weight:500;font-size:.9rem}
.fab-menu a:hover{background:var(--surface-2)}
@keyframes fabIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* PWA install prompt */
.pwa-prompt{position:fixed;left:var(--s-4);right:var(--s-4);bottom:calc(76px + env(safe-area-inset-bottom));background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:var(--s-4);z-index:55;display:flex;gap:var(--s-3);align-items:center;max-width:400px;margin:0 auto;animation:fabIn .3s}
@media(min-width:768px){.pwa-prompt{left:auto;right:var(--s-6);bottom:var(--s-6);margin:0}}
.pwa-prompt[hidden]{display:none}
.pwa-body{flex:1}.pwa-body strong{display:block;color:var(--text);font-size:.95rem}
.pwa-body p{margin:2px 0 0;font-size:.8rem;color:var(--text-muted)}
.pwa-actions{display:flex;gap:var(--s-2);flex-shrink:0}

/* Toasts */
.toast{position:fixed;top:var(--s-4);left:50%;transform:translateX(-50%);padding:var(--s-3) var(--s-5);border-radius:var(--r-md);font-weight:500;font-size:.9rem;box-shadow:var(--shadow-lg);z-index:100;animation:fabIn .3s,toastOut .3s 4s forwards}
.toast-success{background:var(--success);color:#fff}
.toast-danger,.toast-error{background:var(--danger);color:#fff}
.toast-warning{background:var(--warning);color:#fff}
.toast-info{background:var(--text);color:var(--bg)}
@keyframes toastOut{to{opacity:0;transform:translateX(-50%) translateY(-20px)}}

/* Empty states */
.empty{text-align:center;padding:var(--s-12) var(--s-4)}
.empty svg{width:120px;height:120px;margin:0 auto var(--s-4);opacity:.5}
.empty h3{margin-bottom:var(--s-2)}
.empty p{max-width:360px;margin:0 auto var(--s-4)}

/* Skeleton */
.skel{background:linear-gradient(90deg,var(--surface-2) 0%,var(--border) 50%,var(--surface-2) 100%);background-size:200% 100%;animation:shim 1.5s infinite;border-radius:var(--r-sm)}
@keyframes shim{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* Utilities */
.row{display:flex;gap:var(--s-3);flex-wrap:wrap;align-items:center}
.col{display:flex;flex-direction:column;gap:var(--s-3)}
.between{justify-content:space-between}
.center{justify-content:center;align-items:center}
.mt-4{margin-top:var(--s-4)}.mt-6{margin-top:var(--s-6)}.mb-4{margin-bottom:var(--s-4)}
.text-muted{color:var(--text-muted)}.text-center{text-align:center}
.hidden{display:none}
.chip{display:inline-flex;padding:4px 10px;background:var(--primary-soft);color:var(--primary);border-radius:var(--r-full);font-size:.75rem;font-weight:600}
