/* TAKATIM main.css v6
   Titres : Outfit (moderne, tech, propre)
   Corps  : DM Sans (élégant, lisible)
   Mono   : Space Mono
   Thème clair – fond blanc hors hero
*/
:root{
  --cobalt:#1A3FBF;--cobalt-dark:#0D2580;--cobalt-light:#2F5CE6;
  --cobalt-xlight:#EAF0FF;--accent:#00A8CC;
  --bg:#fff;--bg-alt:#F5F7FF;--bg-card:#fff;
  --border:#E2E8F7;--border-strong:#BDC9EE;
  --text:#0D1A3A;--text-muted:#556080;--text-light:#8899BB;
  --shadow-sm:0 2px 10px rgba(26,63,191,.06);
  --shadow-md:0 6px 28px rgba(26,63,191,.11);
  --shadow-lg:0 18px 56px rgba(26,63,191,.14);
  --r-sm:6px;--r-md:12px;--r-lg:20px;
  --font-title:'Outfit',sans-serif;
  --font-body:'DM Sans',sans-serif;
  --font-mono:'Space Mono',monospace;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--bg);color:var(--text);overflow-x:hidden;font-size:16px;line-height:1.65}

/* Titres utilisent Outfit */
h1,h2,h3,h4,h5,
.section-title,
.hero-title,
.page-header-title,
.form-section-title,
.service-title,
.project-name,
.team-name,
.value-card-title,
.service-detail-title,
.job-role,
.cta-title,
.about-strip-title,
.sector-item-name{font-family:var(--font-title)}

/* ── PRELOADER ────────────────────────── */
#preloader{position:fixed;inset:0;background:#050D1A;z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:opacity .6s,visibility .6s}
#preloader.hide{opacity:0;visibility:hidden;pointer-events:none}
.loader-logo{font-family:var(--font-title);font-size:2.4rem;font-weight:800;color:#fff;letter-spacing:.2rem;margin-bottom:1.8rem}
.loader-logo span{color:var(--accent)}
.loader-bar-wrap{width:220px;height:2px;background:rgba(255,255,255,.1);border-radius:2px;overflow:hidden;margin-bottom:1rem}
.loader-bar{height:100%;background:linear-gradient(90deg,var(--cobalt),var(--accent));animation:loadBar 2s ease forwards}
@keyframes loadBar{from{width:0}to{width:100%}}
.loader-text{font-family:var(--font-mono);font-size:.65rem;color:var(--accent);letter-spacing:.15rem;animation:blink 1s step-end infinite}
@keyframes blink{50%{opacity:0}}
.loader-dots{display:flex;gap:8px;margin-top:1.5rem}
.loader-dot{width:8px;height:8px;border-radius:50%;background:var(--cobalt);animation:dotPulse 1.4s ease infinite}
.loader-dot:nth-child(2){animation-delay:.2s;background:var(--cobalt-light)}
.loader-dot:nth-child(3){animation-delay:.4s;background:var(--accent)}
@keyframes dotPulse{0%,80%,100%{transform:scale(1);opacity:.5}40%{transform:scale(1.4);opacity:1}}

/* ── CURSOR ──────────────────────────── */
.cursor,.cursor-ring{display:none}
@media(hover:hover) and (pointer:fine){
  .cursor{display:block;position:fixed;width:10px;height:10px;background:var(--cobalt);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:width .3s,height .3s}
  .cursor-ring{display:block;position:fixed;width:34px;height:34px;border:1.5px solid rgba(26,63,191,.3);border-radius:50%;pointer-events:none;z-index:9997;transform:translate(-50%,-50%);transition:all .15s ease}
}

/* ── NAVBAR ──────────────────────────── */
nav.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:.9rem 0;transition:background .35s,box-shadow .35s,padding .35s}
nav.navbar.scrolled{background:rgba(255,255,255,.97);backdrop-filter:blur(16px);padding:.55rem 0;box-shadow:0 2px 20px rgba(26,63,191,.09)}
.nav-logo{height:40px;width:auto;object-fit:contain;display:block}
@media(max-width:576px){.nav-logo{height:32px}}
.nav-link{color:rgba(255,255,255,.92)!important;font-family:var(--font-body);font-size:.77rem;font-weight:600;letter-spacing:.06rem;text-transform:uppercase;padding:.4rem .75rem!important;transition:color .3s;position:relative;white-space:nowrap}
.nav-link::after{content:'';position:absolute;bottom:-2px;left:50%;right:50%;height:2px;background:var(--accent);transition:left .3s,right .3s}
.nav-link:hover::after,.nav-link.active::after{left:.75rem;right:.75rem}
.nav-link:hover,.nav-link.active{color:#fff!important}
nav.navbar.scrolled .nav-link{color:var(--text)!important}
nav.navbar.scrolled .nav-link:hover,nav.navbar.scrolled .nav-link.active{color:var(--cobalt)!important}
nav.navbar.scrolled .nav-link::after{background:var(--cobalt)}
.btn-nav-cta{background:var(--cobalt)!important;color:#fff!important;border-radius:4px;padding:.46rem 1.15rem!important;font-size:.72rem!important;letter-spacing:.07rem;font-weight:700;transition:background .3s,transform .2s;white-space:nowrap}
.btn-nav-cta:hover{background:var(--cobalt-light)!important;transform:translateY(-1px)}
.btn-nav-cta::after{display:none!important}
nav.navbar.scrolled .btn-nav-cta{color:#fff!important}

/* Hamburger */
.navbar-toggler{border:none!important;background:transparent!important;box-shadow:none!important;padding:.2rem .4rem;outline:none!important}
.navbar-toggler:focus{box-shadow:none!important}
.hamburger-icon{display:flex;flex-direction:column;gap:5px;width:24px;cursor:pointer}
.hamburger-icon span{display:block;height:2px;border-radius:2px;background:rgba(255,255,255,.92);transition:background .3s}
nav.navbar.scrolled .hamburger-icon span{background:var(--text)}
@media(max-width:991px){
  .navbar-collapse{background:#fff;border-radius:0 0 12px 12px;box-shadow:var(--shadow-lg);padding:.6rem 1rem 1rem;margin-top:.4rem;border-top:2px solid var(--cobalt-xlight)}
  .navbar-nav{gap:0!important}
  .nav-link{color:var(--text)!important;padding:.6rem .5rem!important}
  .nav-link:hover,.nav-link.active{color:var(--cobalt)!important}
  .nav-link::after{background:var(--cobalt)}
  .nav-item.ms-lg-2{margin-left:0!important;margin-top:.5rem}
  .btn-nav-cta{display:block;text-align:center;width:100%}
}

/* ── MESSAGES ────────────────────────── */
.messages-container{position:fixed;top:80px;right:1rem;z-index:999;max-width:360px;width:calc(100% - 2rem)}
.alert-msg{display:flex;align-items:center;gap:.7rem;background:#fff;border:1px solid var(--border);border-left:3px solid var(--cobalt-light);border-radius:8px;padding:.85rem 1rem;margin-bottom:.5rem;font-size:.83rem;color:var(--text);box-shadow:var(--shadow-md);animation:slideIn .3s ease}
.alert-msg.success{border-left-color:#28a745}
.alert-msg.success i{color:#28a745}
.alert-msg button{margin-left:auto;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1.1rem}
@keyframes slideIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}

/* ── BUTTONS ─────────────────────────── */
.btn-primary-cta{display:inline-flex;align-items:center;gap:.55rem;background:var(--cobalt);color:#fff;border:none;padding:.78rem 1.6rem;font-family:var(--font-body);font-weight:700;font-size:.78rem;letter-spacing:.07rem;text-transform:uppercase;text-decoration:none;border-radius:4px;cursor:pointer;transition:background .3s,transform .2s,box-shadow .3s;white-space:nowrap}
.btn-primary-cta:hover{background:var(--cobalt-light);transform:translateY(-2px);box-shadow:0 8px 22px rgba(26,63,191,.28);color:#fff}
.btn-outline-cta{display:inline-flex;align-items:center;gap:.55rem;background:transparent;color:var(--cobalt);border:1.5px solid var(--cobalt);padding:.78rem 1.6rem;font-family:var(--font-body);font-weight:700;font-size:.78rem;letter-spacing:.07rem;text-transform:uppercase;text-decoration:none;border-radius:4px;cursor:pointer;transition:background .3s,color .3s,transform .2s;white-space:nowrap}
.btn-outline-cta:hover{background:var(--cobalt);color:#fff;transform:translateY(-2px)}
.btn-outline-white{display:inline-flex;align-items:center;gap:.55rem;background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.55);padding:.78rem 1.6rem;font-family:var(--font-body);font-weight:700;font-size:.78rem;letter-spacing:.07rem;text-transform:uppercase;text-decoration:none;border-radius:4px;cursor:pointer;transition:background .3s,border-color .3s,transform .2s;white-space:nowrap}
.btn-outline-white:hover{background:rgba(255,255,255,.12);border-color:#fff;color:#fff;transform:translateY(-2px)}
.btn-sm-cta{display:inline-flex;align-items:center;gap:.4rem;background:var(--cobalt-xlight);color:var(--cobalt);border:1px solid var(--border-strong);padding:.38rem .85rem;font-family:var(--font-body);font-weight:700;font-size:.69rem;letter-spacing:.06rem;text-transform:uppercase;text-decoration:none;border-radius:4px;cursor:pointer;transition:background .3s,color .3s;white-space:nowrap}
.btn-sm-cta:hover{background:var(--cobalt);color:#fff}
@media(max-width:576px){
  .btn-primary-cta,.btn-outline-cta,.btn-outline-white{padding:.72rem 1.2rem;font-size:.74rem}
  .hero-actions{flex-direction:column;align-items:flex-start;gap:.75rem}
  .hero-actions .btn-primary-cta,.hero-actions .btn-outline-white{width:100%;justify-content:center}
}

/* ── SECTIONS ────────────────────────── */
section{padding:5rem 0}
@media(max-width:768px){section{padding:3.2rem 0}}
.section-eyebrow{font-family:var(--font-mono);font-size:.6rem;color:var(--cobalt-light);letter-spacing:.28rem;text-transform:uppercase;display:flex;align-items:center;gap:.65rem;margin-bottom:.75rem}
.section-eyebrow::before{content:'';display:block;width:24px;height:2px;background:var(--cobalt-light)}
.section-eyebrow.center{justify-content:center}
.section-title{font-family:var(--font-title);font-size:clamp(1.7rem,3.5vw,2.7rem);font-weight:700;line-height:1.15;color:var(--text);margin-bottom:.9rem}
.section-subtitle{font-size:.95rem;color:var(--text-muted);line-height:1.8;max-width:560px}

/* ── REVEAL ──────────────────────────── */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .75s ease,transform .75s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ── FORMS ───────────────────────────── */
.form-label{font-size:.69rem;font-weight:600;color:var(--text-muted);letter-spacing:.07rem;text-transform:uppercase;margin-bottom:.3rem;display:block}
.form-ctrl{width:100%;background:var(--bg-alt);border:1.5px solid var(--border);border-radius:var(--r-sm);padding:.7rem .9rem;color:var(--text);font-family:var(--font-body);font-size:.87rem;transition:border-color .3s,box-shadow .3s;outline:none}
.form-ctrl:focus{border-color:var(--cobalt-light);box-shadow:0 0 0 3px rgba(26,63,191,.09);background:#fff}
.form-ctrl::placeholder{color:var(--text-light)}
select.form-ctrl option{background:#fff;color:var(--text)}
textarea.form-ctrl{resize:vertical;min-height:110px}
.form-error{font-size:.69rem;color:#dc3545;margin-top:.28rem}
.form-section-title{font-family:var(--font-title);font-size:1.5rem;font-weight:700;color:var(--text);margin-bottom:1.5rem}
.form-section-title span{color:var(--cobalt)}

/* UPLOAD */
.upload-zone{border:2px dashed var(--border-strong);border-radius:var(--r-sm);padding:1.3rem 1rem;text-align:center;cursor:pointer;background:var(--bg-alt);transition:border-color .3s,background .3s;min-height:100px;display:flex;flex-direction:column;align-items:center;justify-content:center}
.upload-zone:hover,.upload-zone.has-file{border-color:var(--cobalt-light);background:var(--cobalt-xlight)}
.upload-zone.has-file{border-style:solid}

/* ── PAGE HEADER ─────────────────────── */
.page-header{padding:8.5rem 0 4rem;background:linear-gradient(135deg,var(--cobalt-dark) 0%,var(--cobalt-light) 100%);position:relative;overflow:hidden}
.page-header::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.055) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.055) 1px,transparent 1px);background-size:50px 50px}
.page-header::after{content:'';position:absolute;top:-80px;right:-80px;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.08),transparent 70%)}
.page-header .container{position:relative;z-index:1}
.page-header-eyebrow{font-family:var(--font-mono);font-size:.6rem;color:rgba(255,255,255,.58);letter-spacing:.28rem;text-transform:uppercase;display:flex;align-items:center;gap:.65rem;margin-bottom:.72rem}
.page-header-eyebrow::before{content:'';width:22px;height:1px;background:rgba(255,255,255,.38)}
.page-header-title{font-family:var(--font-title);font-size:clamp(1.9rem,5vw,3.2rem);font-weight:700;color:#fff;line-height:1.15;margin-bottom:.85rem}
.page-header-sub{font-size:.93rem;color:rgba(255,255,255,.74);line-height:1.8;max-width:540px}
@media(max-width:768px){.page-header{padding:7rem 0 2.5rem}}

/* ── BREADCRUMB ──────────────────────── */
.tk-breadcrumb{display:flex;align-items:center;gap:.35rem;font-size:.73rem;color:rgba(255,255,255,.48);margin-bottom:1rem;flex-wrap:wrap}
.tk-breadcrumb a{color:rgba(255,255,255,.62);text-decoration:none;transition:color .3s}
.tk-breadcrumb a:hover{color:#fff}
.tk-breadcrumb .sep{color:rgba(255,255,255,.2)}
.tk-breadcrumb .current{color:rgba(255,255,255,.88)}

/* ── EXPERTISE ───────────────────────── */
.expertise-item{border-bottom:1px solid var(--border);padding:1.15rem 0}
.expertise-number{font-family:var(--font-mono);font-size:.62rem;color:var(--cobalt-light);margin-bottom:.28rem}
.expertise-head{display:flex;justify-content:space-between;align-items:center}
.expertise-name{font-size:.94rem;font-weight:600;color:var(--text)}
.expertise-pct{font-family:var(--font-mono);font-size:.76rem;color:var(--cobalt);font-weight:700}
.expertise-bar-wrap{height:5px;background:var(--border);margin-top:.72rem;border-radius:5px;overflow:hidden}
.expertise-bar{height:100%;background:linear-gradient(90deg,var(--cobalt),var(--cobalt-light));border-radius:5px;width:0;transition:width 1.5s cubic-bezier(.16,1,.3,1)}

/* ── TEAM & VALUES ───────────────────── */
.team-card,.value-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-sm);transition:box-shadow .3s,transform .3s,border-color .3s}
.team-card{padding:1.75rem;text-align:center}
.value-card{padding:1.65rem;height:100%}
.team-card:hover,.value-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px);border-color:var(--border-strong)}
.team-avatar{width:66px;height:66px;border-radius:50%;background:var(--cobalt-xlight);border:2px solid var(--cobalt-light);display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin:0 auto .85rem;color:var(--cobalt)}
.team-name{font-family:var(--font-title);font-weight:700;font-size:.95rem;color:var(--text);margin-bottom:.18rem}
.team-role{font-size:.69rem;color:var(--cobalt);font-family:var(--font-mono);letter-spacing:.07rem}
.team-dept{font-size:.75rem;color:var(--text-muted);margin-top:.25rem}
.value-card-icon{width:48px;height:48px;border-radius:11px;background:var(--cobalt-xlight);border:1px solid var(--border-strong);display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:var(--cobalt);margin-bottom:.95rem}
.value-card-title{font-family:var(--font-title);font-weight:700;font-size:.97rem;margin-bottom:.42rem;color:var(--text)}
.value-card-text{font-size:.83rem;color:var(--text-muted);line-height:1.7}

/* ── SERVICES detail ─────────────────── */
.service-detail-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:2.5rem;margin-bottom:1.5rem;box-shadow:var(--shadow-sm);position:relative;overflow:hidden;transition:box-shadow .3s}
.service-detail-card:hover{box-shadow:var(--shadow-md)}
.service-detail-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--cobalt),var(--cobalt-light))}
.service-detail-icon{width:58px;height:58px;border-radius:13px;background:var(--cobalt-xlight);border:1px solid var(--border-strong);display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:var(--cobalt);margin-bottom:1.15rem}
.service-detail-title{font-family:var(--font-title);font-size:1.4rem;font-weight:700;color:var(--text);margin-bottom:.85rem}
.service-detail-desc{font-size:.91rem;color:var(--text-muted);line-height:1.9;margin-bottom:1.1rem}
.service-features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(185px,1fr));gap:.62rem;margin-top:1.1rem}
.service-feature-item{display:flex;align-items:flex-start;gap:.48rem;font-size:.81rem;color:var(--text-muted)}
.service-feature-item i{color:var(--cobalt-light);flex-shrink:0;margin-top:.1rem}
@media(max-width:768px){.service-detail-card{padding:1.4rem}}

/* ── JOB BADGES ──────────────────────── */
.job-badge{font-size:.62rem;font-family:var(--font-mono);padding:.16rem .52rem;border-radius:3px;letter-spacing:.04rem}
.job-badge.dept{background:var(--cobalt-xlight);color:var(--cobalt);border:1px solid var(--border-strong)}
.job-badge.type{background:rgba(0,168,204,.07);color:var(--accent);border:1px solid rgba(0,168,204,.2)}

/* ── PARTNERS ────────────────────────── */
.partners-row-label{font-family:var(--font-mono);font-size:.59rem;color:black !important;letter-spacing:.2rem;text-transform:uppercase;margin-bottom:.5rem;padding-left:.5rem}
.partners-separator{height:1px;background:var(--border);margin:.75rem 0}

/* ── FOOTER ──────────────────────────── */
footer{background:#050D1A;border-top:1px solid rgba(255,255,255,.06);padding:4rem 0 2rem}
.footer-logo{height:30px;margin-bottom:1rem;display:block}
.footer-logo-text{font-family:var(--font-title);font-size:1.5rem;font-weight:800;color:#fff;margin-bottom:1rem}
.footer-logo-text span{color:var(--accent)}
.footer-desc{font-size:.81rem;color:rgba(255,255,255,.38);line-height:1.8;max-width:270px}
.footer-contact-lines{margin-top:.9rem;display:flex;flex-direction:column;gap:.42rem}
.footer-contact-line{display:flex;align-items:center;gap:.48rem;font-size:.79rem;color:rgba(255,255,255,.38);text-decoration:none;transition:color .3s}
.footer-contact-line:hover{color:#fff}
.footer-contact-line i{color:var(--cobalt-light);font-size:.84rem}
.footer-title{font-family:var(--font-title);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.12rem;margin-bottom:1rem;color:rgba(255,255,255,.26)}
.footer-links{list-style:none;padding:0}
.footer-links li{margin-bottom:.48rem}
.footer-links a{color:rgba(255,255,255,.38);text-decoration:none;font-size:.8rem;transition:color .3s,padding-left .3s;display:inline-block}
.footer-links a:hover{color:#fff;padding-left:4px}
.footer-divider{border-color:rgba(255,255,255,.07);margin:1.6rem 0}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.8rem}
.footer-copy{font-size:.72rem;color:rgba(255,255,255,.18)}
.footer-legal-links{display:flex;align-items:center;gap:.28rem;flex-wrap:wrap}
.footer-legal{color:rgba(255,255,255,.18);text-decoration:none;font-size:.72rem;transition:color .3s}
.footer-legal:hover{color:#fff}
.footer-sep{color:rgba(255,255,255,.1)}
.social-links{display:flex;gap:.55rem;margin-top:.7rem}
.social-btn{width:33px;height:33px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:50%;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.34);font-size:.84rem;text-decoration:none;transition:background .3s,border-color .3s,color .3s}
.social-btn:hover{background:var(--cobalt);border-color:var(--cobalt-light);color:#fff}

/* ── COOKIE BANNER ───────────────────── */
#cookie-banner{position:fixed;bottom:1.2rem;left:50%;transform:translateX(-50%);z-index:9990;width:calc(100% - 2rem);max-width:880px;background:#fff;border:1px solid var(--border);border-radius:var(--r-md);padding:1.1rem 1.4rem;box-shadow:var(--shadow-lg);display:none;animation:slideUpBanner .4s ease}
@keyframes slideUpBanner{from{opacity:0;transform:translateX(-50%) translateY(18px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
.cookie-inner{display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap}
.cookie-text{display:flex;align-items:flex-start;gap:.72rem;flex:1;font-size:.81rem;color:var(--text-muted);line-height:1.6}
.cookie-text a{color:var(--cobalt);text-decoration:none}
.cookie-text i{color:var(--cobalt-light);font-size:1.05rem;flex-shrink:0;margin-top:.1rem}
.cookie-actions{display:flex;align-items:center;gap:.65rem;flex-shrink:0}
.btn-cookie-refuse{background:transparent;border:1px solid var(--border);color:var(--text-muted);padding:.36rem .85rem;border-radius:4px;font-size:.71rem;font-weight:600;cursor:pointer;font-family:var(--font-body);transition:border-color .3s,color .3s}
.btn-cookie-refuse:hover{border-color:var(--cobalt);color:var(--cobalt)}

/* ── LEGAL ───────────────────────────── */
.legal-content{max-width:100%;margin:0;font-size:.93rem;color:var(--text-muted);line-height:1.9}
.legal-content h2{font-family:var(--font-title);font-size:1.25rem;font-weight:700;color:var(--text);margin-top:2.2rem;margin-bottom:.85rem;padding-bottom:.42rem;border-bottom:2px solid var(--cobalt-xlight)}
.legal-content h3{font-size:.96rem;font-weight:700;margin-top:1.3rem;margin-bottom:.5rem;color:var(--cobalt)}
.legal-content p{margin-bottom:.88rem}
.legal-content ul{padding-left:1.3rem;margin-bottom:.88rem}
.legal-content ul li{margin-bottom:.32rem}
.legal-content a{color:var(--cobalt);text-decoration:none}
.legal-content a:hover{text-decoration:underline}
.legal-toc{background:var(--cobalt-xlight);border:1px solid var(--border-strong);border-radius:var(--r-md);padding:1.3rem 1.7rem;margin-bottom:2.3rem}
.legal-toc-title{font-family:var(--font-title);font-weight:700;font-size:.82rem;text-transform:uppercase;letter-spacing:.1rem;margin-bottom:.85rem;color:var(--cobalt)}
.legal-toc ol{margin:0;padding-left:1rem}
.legal-toc ol li{margin-bottom:.32rem;font-size:.86rem}
.cookie-type-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);padding:1.4rem;margin-bottom:1rem}
.cookie-type-header{display:flex;align-items:center;gap:.9rem;margin-bottom:.75rem}
.cookie-type-badge{font-family:var(--font-mono);font-size:.59rem;padding:.18rem .58rem;border-radius:3px;font-weight:700}
.badge-essential{background:rgba(40,167,69,.08);color:#28a745;border:1px solid rgba(40,167,69,.2)}
.badge-analytics{background:var(--cobalt-xlight);color:var(--cobalt);border:1px solid var(--border-strong)}
.badge-functional{background:rgba(0,168,204,.07);color:var(--accent);border:1px solid rgba(0,168,204,.2)}
.cookie-name{font-family:var(--font-title);font-weight:700;font-size:.93rem;color:var(--text)}
.cookie-desc{font-size:.82rem;color:var(--text-muted);line-height:1.7}
.modal-content{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);color:var(--text)}

/* ── LEGAL TABLES ─────────────────────── */
.legal-table-wrap{overflow-x:auto;margin:1rem 0 1.5rem}
.legal-table{width:100%;border-collapse:collapse;font-size:.86rem}
.legal-table th{background:var(--cobalt-xlight);color:var(--cobalt);font-weight:700;text-align:left;padding:.65rem 1rem;border-bottom:2px solid var(--border-strong);white-space:nowrap}
.legal-table td{padding:.6rem 1rem;border-bottom:1px solid var(--border);color:var(--text-muted);vertical-align:top}
.legal-table tr:last-child td{border-bottom:none}
.legal-table tr:hover td{background:var(--bg-alt)}
.legal-table code{font-family:'Space Mono',monospace;font-size:.8rem;background:var(--bg-alt);padding:.1rem .35rem;border-radius:3px;color:var(--cobalt)}
.modal-header,.modal-footer{border-color:var(--border)!important}

@media(max-width:768px){
  #cookie-banner{bottom:0;left:0;right:0;width:100%;transform:none;border-radius:var(--r-md) var(--r-md) 0 0}
  .cookie-inner{flex-direction:column;gap:.8rem}
}