/*
Theme Name:  Startup LLab
Theme URI:   https://startup.llab.cd
Author:      Lumumba Lab
Description: Annuaire de l'écosystème numérique congolais — startups, accompagnement, financement.
Version:     1.0.0
Text Domain: startup-llab
*/

/* ============================================================
   TOKENS
   ============================================================ */
:root {
    --white:     #ffffff;
    --off:       #fafaf8;
    --sand:      #f4f2ee;
    --sand-2:    #ede9e3;
    --sand-3:    #e0dbd2;
    --ink:       #181614;
    --ink-2:     #3c3833;
    --ink-3:     #7a746c;
    --ink-4:     #b0a99f;
    --orange:    #e06030;
    --orange-2:  #f07848;
    --orange-p:  rgba(224,96,48,.09);
    --orange-m:  rgba(224,96,48,.18);
    --border:    rgba(24,22,20,.09);
    --border-2:  rgba(24,22,20,.16);
    --shadow:    0 1px 4px rgba(24,22,20,.06),0 4px 20px rgba(24,22,20,.07);
    --shadow-lg: 0 8px 32px rgba(24,22,20,.10),0 24px 64px rgba(24,22,20,.09);
    --r:         4px;
    --r-lg:      8px;
    --tr:        .3s cubic-bezier(.4,0,.2,1);
    /* Groupes */
    --c-startup:   #1a5cbf;
    --c-startup-p: rgba(26,92,191,.09);
    --c-accomp:    #1a6b3a;
    --c-accomp-p:  rgba(26,107,58,.09);
    --c-finance:   #7b3fa0;
    --c-finance-p: rgba(123,63,160,.09);
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;font-size:16px;}
body{
    font-family:'DM Sans',sans-serif;
    background:var(--off);color:var(--ink);
    -webkit-font-smoothing:antialiased;overflow-x:hidden;line-height:1.65;
}
img{max-width:100%;display:block;}
a{text-decoration:none;color:inherit;}
ul{list-style:none;}
button{font-family:inherit;cursor:pointer;border:none;}

/* ── LAYOUT ── */
.wrap{max-width:1280px;margin:0 auto;padding:0 64px;}

/* ── NAV ── */
.site-nav{
    position:fixed;top:0;left:0;right:0;z-index:900;height:64px;
    background:rgba(250,250,248,.96);backdrop-filter:blur(18px);
    border-bottom:1px solid var(--border);display:flex;align-items:center;
}
.nav-inner{
    width:100%;max-width:1280px;margin:0 auto;padding:0 64px;
    display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.nav-brand{display:flex;align-items:center;gap:10px;}
.nav-brand-logo{
    font-family:'DM Serif Display',serif;font-size:1.1rem;color:var(--ink);
}
.nav-brand-logo span{color:var(--orange);}
.nav-back{
    font-size:.75rem;font-weight:500;letter-spacing:.5px;
    color:var(--ink-3);display:flex;align-items:center;gap:6px;
    transition:color var(--tr);
}
.nav-back::before{content:'←';}
.nav-back:hover{color:var(--orange);}
.nav-right{display:flex;align-items:center;gap:12px;}
.nav-count{
    font-size:.75rem;font-weight:500;color:var(--ink-3);
    background:var(--sand);border:1px solid var(--border);
    padding:5px 12px;border-radius:20px;
}
.nav-count span{color:var(--orange);font-weight:700;}
.btn-add{
    background:var(--orange);color:#fff;font-size:.75rem;font-weight:500;
    padding:8px 18px;border-radius:var(--r);transition:var(--tr);
    display:inline-flex;align-items:center;gap:6px;
}
.btn-add svg{width:14px;height:14px;fill:#fff;}
.btn-add:hover{background:var(--orange-2);transform:translateY(-1px);}

/* ── HERO ── */
.hero{
    padding:120px 0 80px;background:var(--ink);
    position:relative;overflow:hidden;
}
.hero::before{
    content:'';position:absolute;inset:0;
    background:
        radial-gradient(ellipse 60% 80% at 80% 50%,rgba(224,96,48,.12),transparent 60%),
        radial-gradient(ellipse 50% 60% at 10% 80%,rgba(26,92,191,.08),transparent 55%);
}
.hero-grid-deco{
    position:absolute;inset:0;pointer-events:none;
    background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),
                     linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
    background-size:72px 72px;
}
.hero-inner{position:relative;z-index:1;}
.hero-kicker{
    display:inline-flex;align-items:center;gap:8px;
    font-size:.7rem;font-weight:500;letter-spacing:2.5px;text-transform:uppercase;
    color:rgba(255,255,255,.4);margin-bottom:20px;
}
.kicker-dot{
    width:6px;height:6px;border-radius:50%;background:var(--orange);
    animation:kpulse 2.2s ease infinite;
}
@keyframes kpulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.3;transform:scale(.7);}}
.hero-title{
    font-family:'DM Serif Display',serif;
    font-size:clamp(2.6rem,5vw,4.4rem);font-weight:400;line-height:1.05;
    color:#fff;margin-bottom:20px;max-width:760px;
}
.hero-title em{font-style:italic;color:var(--orange);}
.hero-desc{
    font-size:1.05rem;line-height:1.75;color:rgba(255,255,255,.55);
    max-width:580px;margin-bottom:48px;font-weight:300;
}
.hero-groups{display:flex;gap:16px;flex-wrap:wrap;}
.hero-group-pill{
    display:flex;align-items:center;gap:10px;
    background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
    border-radius:40px;padding:10px 20px;
}
.hero-group-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.hero-group-dot.startup{background:#4d8cf0;}
.hero-group-dot.accomp {background:#3da868;}
.hero-group-dot.finance{background:#b07ae0;}
.hero-group-label{font-size:.78rem;color:rgba(255,255,255,.6);}
.hero-group-count{
    font-family:'DM Serif Display',serif;
    font-size:1rem;color:#fff;margin-left:4px;
}

/* ── FILTERS BAR ── */
.filters-bar{
    background:var(--white);border-bottom:1px solid var(--border);
    position:sticky;top:64px;z-index:800;padding:14px 0;
}
.filters-inner{display:flex;align-items:center;gap:14px;flex-wrap:wrap;}
.search-box{position:relative;flex:1;min-width:200px;max-width:340px;}
.search-box svg{
    position:absolute;left:11px;top:50%;transform:translateY(-50%);
    width:15px;height:15px;fill:var(--ink-4);pointer-events:none;
}
#searchInput{
    width:100%;padding:9px 12px 9px 34px;
    background:var(--sand);border:1.5px solid var(--border);border-radius:var(--r);
    font-family:'DM Sans',sans-serif;font-size:.86rem;color:var(--ink);outline:none;
    transition:border-color var(--tr),background var(--tr);
}
#searchInput:focus{border-color:var(--orange);background:var(--white);}
#searchInput::placeholder{color:var(--ink-4);}
.filter-group{display:flex;align-items:center;gap:6px;flex-wrap:wrap;}
.filter-label{
    font-size:.68rem;font-weight:500;letter-spacing:1.5px;
    text-transform:uppercase;color:var(--ink-4);white-space:nowrap;
}
.chip{
    font-size:.75rem;font-weight:400;padding:6px 14px;border-radius:20px;
    border:1.5px solid var(--border);background:var(--white);color:var(--ink-3);
    cursor:pointer;transition:var(--tr);white-space:nowrap;
}
.chip:hover{border-color:var(--border-2);color:var(--ink);}
.chip.on-all    {background:var(--orange-p);border-color:var(--orange);color:var(--orange);}
.chip.on-startup{background:var(--c-startup-p);border-color:var(--c-startup);color:var(--c-startup);}
.chip.on-accomp {background:var(--c-accomp-p);border-color:var(--c-accomp);color:var(--c-accomp);}
.chip.on-finance{background:var(--c-finance-p);border-color:var(--c-finance);color:var(--c-finance);}
.chip-clear{color:var(--ink-4);border-style:dashed;}
.chip-clear:hover{color:var(--orange);border-color:var(--orange);}
#villeFilter{
    font-size:.78rem;padding:6px 12px;border-radius:20px;
    border:1.5px solid var(--border);background:var(--white);
    font-family:'DM Sans',sans-serif;color:var(--ink-3);
    cursor:pointer;outline:none;transition:border-color var(--tr);
}
#villeFilter:focus{border-color:var(--orange);}
.view-toggle{display:flex;gap:4px;margin-left:auto;}
.view-btn{
    width:34px;height:34px;border-radius:var(--r);
    border:1.5px solid var(--border);background:var(--white);
    display:flex;align-items:center;justify-content:center;
    cursor:pointer;transition:var(--tr);
}
.view-btn svg{width:16px;height:16px;fill:var(--ink-4);}
.view-btn.active{background:var(--orange-p);border-color:var(--orange);}
.view-btn.active svg{fill:var(--orange);}

/* ── MAIN ── */
.site-main{padding:48px 0 96px;}
.results-bar{
    display:flex;align-items:center;justify-content:space-between;
    margin-bottom:28px;flex-wrap:wrap;gap:12px;
}
.results-count{font-size:.85rem;color:var(--ink-3);}
.results-count strong{color:var(--ink);font-weight:500;}

/* ── SECTION HEADER ── */
.sec-header{
    display:flex;align-items:center;gap:14px;
    padding:24px 0 16px;margin-bottom:20px;
    border-bottom:1px solid var(--border);margin-top:56px;
}
.sec-header:first-child{margin-top:0;}
.sec-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;}
.sec-dot.startup{background:var(--c-startup);}
.sec-dot.accomp {background:var(--c-accomp);}
.sec-dot.finance{background:var(--c-finance);}
.sec-title{font-family:'DM Serif Display',serif;font-size:1.5rem;color:var(--ink);}
.sec-badge{
    font-size:.68rem;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;
    padding:4px 10px;border-radius:2px;
}
.sec-badge.startup{background:var(--c-startup-p);color:var(--c-startup);}
.sec-badge.accomp {background:var(--c-accomp-p);color:var(--c-accomp);}
.sec-badge.finance{background:var(--c-finance-p);color:var(--c-finance);}

/* ── CAT TABS ── */
.cat-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px;}
.cat-tab{
    font-size:.75rem;padding:5px 13px;border-radius:20px;
    border:1.5px solid var(--border);background:var(--white);
    color:var(--ink-3);cursor:pointer;transition:var(--tr);
}
.cat-tab:hover{border-color:var(--border-2);color:var(--ink);}
.cat-tab.on.startup{background:var(--c-startup-p);border-color:var(--c-startup);color:var(--c-startup);}
.cat-tab.on.accomp {background:var(--c-accomp-p);border-color:var(--c-accomp);color:var(--c-accomp);}
.cat-tab.on.finance{background:var(--c-finance-p);border-color:var(--c-finance);color:var(--c-finance);}

/* ── CARDS GRID ── */
.cards-grid{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
    gap:20px;
}
.cards-grid.list-view{grid-template-columns:1fr;}

/* ── CARD ── */
.acteur-card{
    background:var(--white);border:1px solid var(--border);border-radius:var(--r-lg);
    padding:24px;display:flex;flex-direction:column;
    transition:box-shadow var(--tr),transform var(--tr),border-color var(--tr);
    position:relative;overflow:hidden;
}
.acteur-card::before{
    content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
    opacity:0;transition:opacity var(--tr);
}
.acteur-card.startup::before{background:var(--c-startup);}
.acteur-card.accomp::before {background:var(--c-accomp);}
.acteur-card.finance::before{background:var(--c-finance);}
.acteur-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);border-color:transparent;}
.acteur-card:hover::before{opacity:1;}

.card-head{display:flex;align-items:flex-start;gap:14px;margin-bottom:14px;}
.card-logo{
    width:44px;height:44px;border-radius:var(--r);flex-shrink:0;
    display:flex;align-items:center;justify-content:center;
    font-family:'DM Serif Display',serif;font-size:1.2rem;color:var(--ink-3);
    text-transform:uppercase;border:1px solid var(--border);
}
.acteur-card.startup .card-logo{background:var(--c-startup-p);color:var(--c-startup);}
.acteur-card.accomp  .card-logo{background:var(--c-accomp-p);color:var(--c-accomp);}
.acteur-card.finance .card-logo{background:var(--c-finance-p);color:var(--c-finance);}
.card-logo img{width:100%;height:100%;object-fit:contain;border-radius:var(--r);}

.card-name{font-size:.95rem;font-weight:500;color:var(--ink);margin-bottom:4px;line-height:1.2;}
.card-cats{display:flex;gap:5px;flex-wrap:wrap;}
.card-cat{
    font-size:.65rem;font-weight:500;letter-spacing:1px;
    text-transform:uppercase;padding:2px 8px;border-radius:2px;
}
.acteur-card.startup .card-cat{background:var(--c-startup-p);color:var(--c-startup);}
.acteur-card.accomp  .card-cat{background:var(--c-accomp-p);color:var(--c-accomp);}
.acteur-card.finance .card-cat{background:var(--c-finance-p);color:var(--c-finance);}
.card-cat-detail{
    font-size:.65rem;padding:2px 8px;border-radius:2px;
    background:var(--sand);color:var(--ink-3);letter-spacing:.5px;
}

.card-desc{
    font-size:.84rem;line-height:1.65;color:var(--ink-3);
    flex:1;margin-bottom:14px;
}
.card-city{
    display:inline-flex;align-items:center;gap:5px;
    font-size:.72rem;color:var(--ink-4);margin-bottom:10px;
}
.card-city svg{width:11px;height:11px;fill:var(--ink-4);}
.card-founders{
    display:flex;align-items:center;gap:6px;
    font-size:.78rem;color:var(--ink-2);margin-bottom:12px;
}
.card-founders svg{width:13px;height:13px;fill:var(--ink-4);flex-shrink:0;}
.card-links{
    display:flex;gap:8px;flex-wrap:wrap;
    padding-top:14px;border-top:1px solid var(--border);margin-top:auto;
}
.card-link{
    display:inline-flex;align-items:center;gap:5px;
    font-size:.72rem;color:var(--ink-3);padding:5px 10px;
    border-radius:var(--r);background:var(--sand);border:1px solid var(--border);
    transition:var(--tr);white-space:nowrap;
}
.card-link svg{width:12px;height:12px;fill:currentColor;}
.card-link:hover{color:var(--orange);background:var(--orange-p);border-color:var(--orange-m);}
.card-verified{
    position:absolute;top:14px;right:14px;
    width:20px;height:20px;border-radius:50%;
    background:var(--c-accomp-p);border:1px solid var(--c-accomp);
    display:flex;align-items:center;justify-content:center;
    title:'Vérifié';
}
.card-verified svg{width:10px;height:10px;fill:var(--c-accomp);}

/* List view */
.cards-grid.list-view .acteur-card{flex-direction:row;align-items:center;padding:16px 24px;gap:20px;}
.cards-grid.list-view .card-head{margin-bottom:0;flex-shrink:0;min-width:200px;}
.cards-grid.list-view .card-desc{display:none;}
.cards-grid.list-view .card-founders{margin-bottom:0;}
.cards-grid.list-view .card-city{margin-bottom:0;}
.cards-grid.list-view .card-links{margin-left:auto;margin-top:0;padding-top:0;border-top:none;flex-shrink:0;}

/* Loading / empty */
.loading-state,.empty-state{
    grid-column:1/-1;padding:80px 40px;text-align:center;color:var(--ink-4);
}
.loading-state svg,.empty-state svg{width:36px;height:36px;fill:var(--sand-3);margin:0 auto 14px;}
.empty-state h3{font-family:'DM Serif Display',serif;font-size:1.2rem;color:var(--ink-3);margin-bottom:6px;}
.empty-state p{font-size:.85rem;}
.spinner{
    width:36px;height:36px;border:3px solid var(--sand-3);
    border-top-color:var(--orange);border-radius:50%;
    animation:spin .8s linear infinite;margin:0 auto 14px;
}
@keyframes spin{to{transform:rotate(360deg);}}

/* ── MODAL ── */
.modal-overlay{
    position:fixed;inset:0;z-index:2000;
    background:rgba(24,22,20,.6);backdrop-filter:blur(6px);
    display:flex;align-items:center;justify-content:center;
    opacity:0;visibility:hidden;transition:opacity var(--tr),visibility var(--tr);
    padding:20px;
}
.modal-overlay.open{opacity:1;visibility:visible;}
.modal{
    background:var(--white);border-radius:var(--r-lg);
    width:100%;max-width:680px;max-height:90vh;overflow-y:auto;
    padding:36px;transform:translateY(20px);
    transition:transform var(--tr);position:relative;
}
.modal-overlay.open .modal{transform:translateY(0);}
.modal-close{
    position:absolute;top:16px;right:16px;
    width:32px;height:32px;border-radius:50%;
    background:var(--sand);border:1px solid var(--border);
    display:flex;align-items:center;justify-content:center;
    cursor:pointer;font-size:1.1rem;color:var(--ink-3);transition:var(--tr);
}
.modal-close:hover{background:var(--sand-2);}
.modal-title{font-family:'DM Serif Display',serif;font-size:1.5rem;color:var(--ink);margin-bottom:4px;}
.modal-sub{font-size:.85rem;color:var(--ink-3);margin-bottom:28px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.fg{display:flex;flex-direction:column;gap:6px;margin-bottom:14px;}
.fg.full{grid-column:1/-1;}
.fg label{font-size:.7rem;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;color:var(--ink-2);}
.fg input,.fg textarea,.fg select{
    background:var(--sand);border:1.5px solid var(--border);border-radius:var(--r);
    padding:10px 14px;font-family:'DM Sans',sans-serif;font-size:.9rem;color:var(--ink);
    outline:none;transition:border-color var(--tr),background var(--tr);
    -webkit-appearance:none;width:100%;
}
.fg input:focus,.fg textarea:focus,.fg select:focus{
    border-color:var(--orange);background:var(--white);box-shadow:0 0 0 3px var(--orange-p);
}
.fg input::placeholder,.fg textarea::placeholder{color:var(--ink-4);}
.fg textarea{resize:vertical;min-height:80px;}
.fg select{cursor:pointer;}
.modal-actions{display:flex;gap:12px;margin-top:8px;}
.btn-submit{
    background:var(--orange);color:#fff;
    font-family:'DM Sans',sans-serif;font-size:.82rem;font-weight:500;
    padding:12px 28px;border-radius:var(--r);border:none;cursor:pointer;transition:var(--tr);
}
.btn-submit:hover{background:var(--orange-2);}
.btn-cancel{
    background:var(--sand);color:var(--ink-2);
    font-family:'DM Sans',sans-serif;font-size:.82rem;
    padding:12px 20px;border-radius:var(--r);
    border:1px solid var(--border);cursor:pointer;transition:var(--tr);
}
.btn-cancel:hover{background:var(--sand-2);}
.modal-note{font-size:.75rem;color:var(--ink-4);margin-top:12px;}

/* ── TOAST ── */
.toast{
    position:fixed;bottom:32px;right:32px;z-index:9999;
    background:var(--ink);color:#fff;
    padding:14px 22px;border-radius:var(--r-lg);
    font-size:.85rem;box-shadow:var(--shadow-lg);
    transform:translateY(80px);opacity:0;
    transition:transform .35s ease,opacity .35s ease;
    display:flex;align-items:center;gap:10px;
}
.toast.show{transform:translateY(0);opacity:1;}
.toast.success{background:var(--c-accomp);}
.toast.error{background:#c0392b;}

/* ── FOOTER ── */
.site-footer{
    background:var(--ink);padding:40px 0;
}
.footer-inner{
    display:flex;align-items:center;justify-content:space-between;
    flex-wrap:wrap;gap:16px;
}
.footer-copy{font-size:.75rem;color:rgba(255,255,255,.28);letter-spacing:.5px;}
.footer-links{display:flex;gap:20px;}
.footer-links a{font-size:.75rem;color:rgba(255,255,255,.35);transition:color var(--tr);}
.footer-links a:hover{color:rgba(255,255,255,.7);}

/* ── ADMIN BAR OFFSET ── */
.admin-bar .site-nav{top:32px;}
.admin-bar .filters-bar{top:calc(64px + 32px);}

/* ── RESPONSIVE ── */
@media(max-width:900px){
    .wrap,.nav-inner{padding:0 20px;}
    .hero{padding:100px 0 60px;}
    .nav-back,.nav-count{display:none;}
    .form-row{grid-template-columns:1fr;}
    .modal{padding:24px;}
    .cards-grid.list-view .acteur-card{flex-direction:column;align-items:flex-start;}
    .cards-grid.list-view .card-links{margin-left:0;margin-top:12px;}
}
@media(max-width:600px){
    .hero-title{font-size:2.2rem;}
    .hero-groups{flex-direction:column;}
    .cards-grid{grid-template-columns:1fr;}
    .view-toggle{display:none;}
    .filter-group{display:none;}
}
