/* XtreeE shared.css : CSS v50 reproduit a l'identique */
:root{
--navy:#1B4080;--navy-deep:#0D1F3C;--blue:#2E6BAD;--light-blue:#E4EDF7;
--accent:#D4A14A;--accent-light:#F4E5C2;--accent-soft:rgba(212,161,74,.10);
--silver:#C8D6E5;
--white:#ffffff;--off:#F0F4F8;--off2:#E4E8EE;
--dark:#0D1F3C;--text:#1e293b;--muted:#6b7a90;--green:#2a9d6e;
--radius:14px;--radius-lg:20px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Manrope',sans-serif;color:var(--text);background:var(--white);line-height:1.65;-webkit-font-smoothing:antialiased}
.topnav{position:fixed;top:0;left:0;right:0;z-index:200;background:rgba(6,22,64,.95);backdrop-filter:blur(16px);padding:0 48px;display:flex;align-items:center;height:56px;border-bottom:1px solid rgba(255,255,255,.06)}
.topnav-logo{font-family:'Manrope',sans-serif;font-size:20px;font-weight:700;color:var(--white);letter-spacing:-1px;margin-right:40px;cursor:pointer}

.topnav-items{display:flex;gap:0;flex:1;height:100%}
.topnav-item{position:relative;height:100%;display:flex;align-items:center}
.topnav-btn{background:none;border:none;color:rgba(255,255,255,.55);font-family:inherit;font-size:12.5px;font-weight:600;padding:0 18px;height:100%;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:5px;letter-spacing:.01em}
.topnav-btn:hover,.topnav-btn.active{color:var(--white)}
.topnav-btn.active{border-bottom:2px solid var(--accent);color:var(--accent)}
.topnav-dd{position:absolute;top:100%;left:0;background:rgba(6,22,64,.97);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.08);border-radius:0 0 10px 10px;min-width:220px;padding:6px;display:none;box-shadow:0 12px 32px rgba(0,0,0,.3)}
.topnav-item:hover .topnav-dd{display:block}
.topnav-dd a{display:block;padding:9px 14px;border-radius:6px;color:rgba(255,255,255,.6);text-decoration:none;font-size:12px;font-weight:500;transition:all .15s}
.topnav-dd a:hover{background:rgba(255,255,255,.06);color:var(--white)}
.topnav-dd a .dd-icon{display:inline-flex;align-items:center;justify-content:center;width:20px;margin-right:6px;vertical-align:middle}
.topnav-right{margin-left:auto}
.topnav-cta{background:var(--accent);color:var(--dark);padding:7px 18px;border-radius:7px;font-size:12px;font-weight:700;text-decoration:none;transition:all .2s;border:none;cursor:pointer;font-family:inherit}
.topnav-cta:hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(212,161,74,.3)}
.page{display:none}.page.visible{display:block}
.hero{min-height:100vh;background:var(--navy-deep);display:flex;align-items:flex-end;justify-content:flex-start;padding:100px 80px 155px;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.20) 0%,rgba(0,0,0,0) 30%,rgba(0,0,0,0) 55%,rgba(13,31,60,.55) 88%,rgba(13,31,60,.85) 100%);z-index:1}
.hero-bg-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero::after{content:"";position:absolute;inset:0;background:transparent;z-index:1}
.hero-content{position:relative;z-index:2;max-width:620px}
.hero-tag{display:inline-flex;align-items:center;gap:6px;padding:5px 14px;border-radius:999px;background:rgba(212,161,74,.15);border:1px solid rgba(212,161,74,.3);color:var(--accent);font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;margin-bottom:28px}
.hero-tag::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--accent);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.hero h1{font-size:72px;font-weight:600;font-family:'Manrope',sans-serif;color:var(--white);line-height:1.05;letter-spacing:-0.5px;margin-bottom:24px}
.hero h1 .accent-word{color:var(--accent)}
.hero-desc{font-size:17px;color:rgba(255,255,255,.65);line-height:1.7;margin-bottom:36px;max-width:540px}
.hero-buttons{display:flex;gap:12px;margin-bottom:48px}
.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:14px 30px;border-radius:50px;background:var(--accent);color:var(--white);font-size:14px;font-weight:700;text-decoration:none;transition:all .2s;border:1px solid var(--accent);cursor:pointer}
.btn-primary:hover{background:#c5371b;border-color:#c5371b}
.btn-ghost{display:inline-flex;align-items:center;gap:8px;padding:14px 30px;border-radius:50px;background:transparent;border:1px solid rgba(255,255,255,.2);color:rgba(255,255,255,.9);font-size:14px;font-weight:600;text-decoration:none;transition:all .2s}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}
.hero-stats{font-family:'Manrope',sans-serif;font-size:13px;font-weight:400;color:rgba(255,255,255,.4);letter-spacing:.04em}
.h-stat-num{font-family:'Manrope',sans-serif;font-size:32px;font-weight:700;color:var(--white)}
.h-stat-label{font-size:11.5px;color:rgba(255,255,255,.45);letter-spacing:.04em}
.lp-section{padding:100px 60px;position:relative;overflow:hidden;isolation:isolate}
.stag{display:inline-block;padding:4px 12px;border-radius:6px;font-family:'Manrope',sans-serif;font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:12px}
.stag-dark{background:rgba(10,36,99,.06);color:var(--navy)}
.stag-light{background:rgba(212,161,74,.12);color:var(--accent);border:1px solid rgba(212,161,74,.2)}
.stitle{font-size:52px;font-weight:600;font-family:'Manrope',sans-serif;color:var(--dark);line-height:1.05;letter-spacing:-1.2px;margin-bottom:8px}
.ssub{font-size:15px;color:var(--muted);max-width:520px;margin-bottom:48px;line-height:1.7}
.how{background:var(--off)}
.how-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.how-step{padding:28px 22px;background:var(--white);border-radius:16px;border:1px solid rgba(0,0,0,.05);position:relative;transition:all .3s}
.how-step:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.06)}
.how-num{font-family:'Manrope',sans-serif;font-size:32px;font-weight:700;color:var(--off2);margin-bottom:12px}
.how-step h3{font-size:15px;font-weight:800;color:var(--dark);margin-bottom:6px}
.how-step p{font-size:13px;color:var(--muted);line-height:1.6}
.how-arrow{position:absolute;left:-16px;top:50%;transform:translateY(-50%);font-size:16px;color:var(--muted);opacity:.4}
.tech-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:56px}
.tcard{padding:36px;border-radius:var(--radius-lg);border:2px solid rgba(0,0,0,.06);transition:all .3s;position:relative;overflow:hidden}
.tcard:hover{border-color:var(--blue);box-shadow:0 8px 32px rgba(10,36,99,.07)}
.tcard.rec{border-color:var(--navy);background:linear-gradient(145deg,#f4f7ff,#eaf0ff)}
.tcard-badge{position:absolute;top:18px;right:18px;padding:4px 10px;border-radius:6px;font-size:9.5px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}
.tcard-badge-rec{background:var(--navy);color:var(--white)}
.tcard-label{font-family:'Manrope',sans-serif;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--blue);margin-bottom:6px}
.tcard-name{font-size:26px;font-weight:900;color:var(--dark);margin-bottom:2px}
.tcard-tagline{font-size:13.5px;color:var(--muted);margin-bottom:20px}
.tcard-feat{display:flex;align-items:start;gap:10px;margin-bottom:9px}
.tcard-feat .ck{width:16px;height:16px;border-radius:50%;background:rgba(42,157,110,.1);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.tcard-feat .ck svg{width:10px;height:10px}
.tcard-feat span{font-size:13px;color:var(--text)}
.tcard-cta{display:inline-flex;align-items:center;gap:5px;margin-top:18px;color:var(--navy);font-weight:700;font-size:13px;cursor:pointer;background:none;border:none;font-family:inherit;transition:gap .2s}
.tcard-cta:hover{gap:8px}
.upgrades-bg{background:var(--off)}
.up-cols{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:stretch}
.up-col{border-radius:var(--radius-lg);padding:0;overflow:hidden;background:var(--white);display:flex;flex-direction:column}
.up-col.col-blue{border:2px solid rgba(30,86,160,.25);box-shadow:0 4px 20px rgba(30,86,160,.08)}
.up-col.col-amber{border:2px solid rgba(212,161,74,.25);box-shadow:0 4px 20px rgba(212,161,74,.08)}
.up-col-accent{height:5px}
.up-col-accent.blue{background:linear-gradient(90deg,var(--blue),#5a9bd5)}
.up-col-accent.amber{background:linear-gradient(90deg,var(--accent),#D4885A)}
.up-col-body{padding:28px 28px 28px;flex:1;display:flex;flex-direction:column}
.up-col-header{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.up-col-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px}
.up-col-title{font-size:19px;font-weight:800;color:var(--dark)}
.up-col-sub{font-size:12.5px;color:var(--muted);margin-top:2px}
.up-col-includes{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:700;color:var(--navy);margin-bottom:16px;padding:10px 14px;border-radius:8px}
.up-col.col-blue .up-col-includes{background:rgba(30,86,160,.06);border:1px solid rgba(30,86,160,.1)}
.up-col.col-amber .up-col-includes{background:rgba(212,161,74,.06);border:1px solid rgba(212,161,74,.12)}
.up-col-includes svg{flex-shrink:0}
.up-cards{display:flex;flex-direction:column;gap:12px;flex:1}
.up-card{padding:20px 22px;border-radius:12px;color:var(--white);position:relative;overflow:hidden;flex:1;display:flex;flex-direction:column}
.up-card::after{content:'';position:absolute;top:-20px;right:-20px;width:80px;height:80px;border-radius:50%}
.up-col.col-blue .up-card{background:linear-gradient(135deg,#1a3a6b,#1e4d8a);border:1px solid rgba(30,86,160,.3)}
.up-col.col-blue .up-card::after{background:rgba(90,155,213,.1)}
.up-col.col-amber .up-card{background:linear-gradient(135deg,#3C2015,#5A3520);border:1px solid rgba(212,161,74,.3)}
.up-col.col-amber .up-card::after{background:rgba(212,161,74,.1)}
.up-card-head{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.up-card-illust{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.up-card-name{font-size:15px;font-weight:800}
.up-card-quote{font-size:12.5px;font-style:italic;margin-bottom:8px}
.up-col.col-blue .up-card-quote{color:#7eb3ff}
.up-col.col-amber .up-card-quote{color:#D4885A}
.up-card-desc{font-size:12.5px;color:rgba(255,255,255,.6);line-height:1.55}
.trust-strip{background:var(--white);padding:56px 60px;border-bottom:1px solid rgba(0,0,0,.04);position:relative;overflow:hidden;isolation:isolate}
.trust-inner{max-width:1100px;margin:0 auto;text-align:center}
.trust-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:16px}
.trust-logos{display:flex;align-items:center;justify-content:center;gap:40px;flex-wrap:wrap;opacity:.55;filter:grayscale(1)}
.trust-logos span{font-family:'Manrope',sans-serif;font-size:14px;font-weight:700;color:var(--navy);letter-spacing:-.5px}
.trust-stats{display:flex;justify-content:center;gap:48px;margin-top:18px}
.trust-stat{text-align:center}
.trust-stat-num{font-size:28px;font-weight:900;color:var(--navy)}
.trust-stat-label{font-size:11px;color:var(--muted);font-weight:600}
.uc-section{background:var(--white);padding:72px 48px;position:relative;overflow:hidden;isolation:isolate}
.uc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:1100px;margin:32px auto 0}
.uc-card{position:relative;border-radius:14px;overflow:hidden;aspect-ratio:4/3;cursor:pointer;transition:transform .3s}
.uc-card:hover{transform:translateY(-4px)}
.uc-card-bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .4s}
.uc-card:hover .uc-card-bg{transform:scale(1.05)}
.uc-card-overlay{position:absolute;inset:0;background:linear-gradient(0deg,rgba(6,22,64,.85) 0%,rgba(6,22,64,.2) 50%,transparent 100%);display:flex;flex-direction:column;justify-content:flex-end;padding:20px}
.uc-card-cat{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);margin-bottom:4px}
.uc-card-title{font-size:15px;font-weight:800;color:var(--white);line-height:1.3}
.uc-card-desc{font-size:11.5px;color:rgba(255,255,255,.6);margin-top:4px;line-height:1.4}
.uc-more{text-align:center;margin-top:24px}
.uc-more a{font-size:13px;font-weight:700;color:var(--blue);text-decoration:none;transition:color .2s}
.uc-more a:hover{color:var(--accent)}
.app-hero{background:var(--navy-deep);padding:120px 48px 60px;text-align:center}
.app-hero h1{font-size:40px;font-weight:900;color:var(--white);margin-bottom:12px}
.app-hero p{font-size:16px;color:rgba(255,255,255,.5);max-width:600px;margin:0 auto}
.app-filters{display:flex;justify-content:center;gap:8px;margin-top:28px}
.app-filter{padding:7px 18px;border-radius:999px;border:1px solid rgba(255,255,255,.15);background:transparent;color:rgba(255,255,255,.5);font-family:inherit;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s}
.app-filter:hover,.app-filter.active{background:var(--accent);color:var(--dark);border-color:var(--accent)}
.app-gallery{max-width:1200px;margin:0 auto;padding:48px;display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.app-card{border-radius:16px;overflow:hidden;background:var(--white);border:1px solid rgba(0,0,0,.06);transition:all .3s;cursor:pointer}
.app-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.08)}
.app-card-img{aspect-ratio:16/10;background:linear-gradient(135deg,var(--navy),var(--blue));position:relative;display:flex;align-items:center;justify-content:center}
.app-card-img-icon{font-size:48px;opacity:.4}
.app-card-cat{position:absolute;top:12px;left:12px;padding:4px 10px;border-radius:6px;background:rgba(6,22,64,.8);color:var(--accent);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.app-card-body{padding:18px 20px}
.app-card-title{font-size:15px;font-weight:800;color:var(--navy);margin-bottom:6px;line-height:1.3}
.app-card-desc{font-size:12.5px;color:var(--muted);line-height:1.5}
.app-card-meta{display:flex;gap:16px;margin-top:10px;padding-top:10px;border-top:1px solid rgba(0,0,0,.05)}
.app-card-meta span{font-size:11px;color:var(--muted);font-weight:600}
.cust-hero{background:var(--navy-deep);padding:120px 48px 60px;text-align:center}
.cust-hero h1{font-size:40px;font-weight:900;color:var(--white);margin-bottom:12px}
.cust-hero p{font-size:16px;color:rgba(255,255,255,.5);max-width:600px;margin:0 auto}
.cust-stats{display:flex;justify-content:center;gap:60px;margin-top:32px}
.cust-stat{text-align:center}
.cust-stat-num{font-size:42px;font-weight:900;color:var(--accent)}
.cust-stat-label{font-size:13px;color:rgba(255,255,255,.5);font-weight:600}
.cust-section{max-width:1500px;margin:0 auto;padding:60px 48px}
.cust-section h2{font-size:24px;font-weight:800;color:var(--navy);margin-bottom:24px;text-align:center}
.cust-logos{display:grid;grid-template-columns:repeat(6,1fr);gap:24px;margin-bottom:48px;align-items:start;justify-items:center}
.cust-logo{display:flex;align-items:center;justify-content:center;padding:24px 16px;border-radius:12px;background:var(--off);border:1px solid rgba(0,0,0,.04);min-height:72px;transition:all .2s}
.cust-logo:hover{border-color:var(--blue);box-shadow:0 4px 16px rgba(0,0,0,.05)}
.cust-logo span{font-family:'Manrope',sans-serif;font-size:13px;font-weight:700;color:var(--navy);letter-spacing:-.5px}
.cust-map{background:var(--off);border-radius:16px;padding:48px;text-align:center}
.cust-map h3{font-size:18px;font-weight:800;color:var(--navy);margin-bottom:8px}
.cust-map p{font-size:13px;color:var(--muted)}
.cust-map-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:24px}
.cust-country{padding:16px;background:var(--white);border-radius:10px;border:1px solid rgba(0,0,0,.04)}
.cust-country-name{font-size:13px;font-weight:700;color:var(--navy)}
.cust-country-count{font-size:24px;font-weight:900;color:var(--blue)}
.cust-country-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.comp-hero{background:var(--navy-deep);padding:100px 48px 60px;text-align:left}
.comp-hero h1{font-size:52px;font-weight:700;color:var(--white);margin-bottom:16px;letter-spacing:-1px;line-height:1.1}
.comp-hero .comp-since{display:inline-flex;padding:5px 14px;border-radius:999px;background:rgba(212,161,74,.1);border:1px solid rgba(212,161,74,.25);color:var(--accent);font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;margin-bottom:20px}
.comp-hero p{font-size:16px;color:rgba(255,255,255,.72);max-width:640px;margin:0;line-height:1.7}
.comp-section{max-width:1100px;margin:0 auto;padding:80px 48px}
.comp-section h2{font-size:36px;font-weight:700;color:var(--navy-deep);margin-bottom:12px;text-align:left;letter-spacing:-.5px;line-height:1.1}
.comp-section .comp-sub{font-size:16px;color:var(--muted);text-align:left;margin-bottom:32px;max-width:680px;line-height:1.6}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.team-card{text-align:center;padding:24px 16px;border-radius:14px;background:var(--off);border:1px solid rgba(0,0,0,.04);transition:all .3s}
.team-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.06)}
.team-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--navy));margin:0 auto 14px;display:flex;align-items:center;justify-content:center;font-size:28px;color:var(--white);font-weight:800}
.team-name{font-size:14px;font-weight:800;color:var(--navy)}
.team-role{font-size:12px;color:var(--muted);margin-top:2px}
.team-link{display:inline-block;margin-top:8px;font-size:11px;color:var(--blue);text-decoration:none;font-weight:600}
.comp-values{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:32px}
.comp-value{padding:28px;border-radius:14px;background:var(--off);border:1px solid rgba(0,0,0,.04)}
.comp-value-icon{font-size:28px;margin-bottom:12px}
.comp-value h3{font-size:16px;font-weight:700;color:var(--navy-deep);margin-bottom:8px}
.comp-value p{font-size:13px;color:var(--muted);line-height:1.6}
.comp-timeline{max-width:600px;margin:32px 0 0;position:relative;padding-left:28px;border-left:2px solid rgba(212,161,74,.2)}
.comp-tl-item{position:relative;margin-bottom:24px;padding-left:20px}
.comp-tl-item::before{content:'';position:absolute;left:-34px;top:4px;width:12px;height:12px;border-radius:50%;background:var(--accent);border:2px solid var(--white)}
.comp-tl-year{font-size:12px;font-weight:800;color:var(--accent)}
.comp-tl-text{font-size:13px;color:var(--muted);margin-top:2px}
.pkg-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.pkg{padding:28px 22px;border-radius:var(--radius-lg);background:var(--off);border:2px solid transparent;transition:all .3s;display:flex;flex-direction:column}
.pkg:hover{border-color:var(--navy);transform:translateY(-4px);box-shadow:0 12px 36px rgba(10,36,99,.08)}
.pkg.feat{background:linear-gradient(170deg,var(--navy-deep),#1a3570);color:var(--white);border-color:var(--navy)}
.pkg-icon{font-size:24px;margin-bottom:10px}
.pkg-name{font-size:20px;font-weight:900;margin-bottom:2px;color:var(--dark)}
.pkg.feat .pkg-name{color:var(--white)}
.pkg-persona{font-size:11px;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}
.pkg.feat .pkg-persona{color:var(--accent)}
.pkg-desc{font-size:12.5px;color:var(--muted);margin-bottom:18px;line-height:1.55;min-height:36px}
.pkg.feat .pkg-desc{color:rgba(255,255,255,.55)}
.pkg-line{height:1px;background:rgba(0,0,0,.06);margin-bottom:14px}
.pkg.feat .pkg-line{background:rgba(255,255,255,.08)}
.pkg-item{display:flex;align-items:start;gap:7px;margin-bottom:7px;font-size:12px;color:var(--text)}
.pkg.feat .pkg-item{color:rgba(255,255,255,.75)}
.pkg-item .ck{flex-shrink:0;margin-top:2px}
.pkg-item .ck svg{width:12px;height:12px}
.pkg-btn{display:block;text-align:center;padding:11px;border-radius:10px;font-size:12.5px;font-weight:700;text-decoration:none;margin-top:auto;transition:all .2s;cursor:pointer}
.pkg-btn-primary{background:var(--accent);color:var(--dark)}
.pkg-btn-secondary{background:rgba(10,36,99,.05);color:var(--navy)}
.support-bg{background:var(--off)}
.sup-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.sup-card{padding:28px;border-radius:16px;background:var(--white);border:1px solid rgba(0,0,0,.04);transition:all .3s}
.sup-card:hover{box-shadow:0 6px 20px rgba(0,0,0,.05)}
.sup-icon{width:44px;height:44px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:14px}
.sup-card h3{font-size:15px;font-weight:800;margin-bottom:5px}
.sup-card p{font-size:12.5px;color:var(--muted);line-height:1.6}
.deeper-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:800px}
.deeper-card{padding:36px;border-radius:var(--radius-lg);border:2px solid rgba(0,0,0,.06);text-align:center;transition:all .3s;text-decoration:none;color:var(--text);display:flex;flex-direction:column;align-items:center;cursor:pointer;background:var(--white)}
.deeper-card:hover{border-color:var(--navy);transform:translateY(-3px);box-shadow:0 10px 30px rgba(10,36,99,.08)}
.deeper-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:26px;margin-bottom:14px}
.deeper-card h3{font-size:18px;font-weight:800;margin-bottom:4px}
.deeper-card p{font-size:13px;color:var(--muted);line-height:1.6;margin-bottom:16px}
.deeper-link{font-size:13px;font-weight:700;color:var(--navy);display:inline-flex;align-items:center;gap:5px}
.contact-section{background:var(--off);color:var(--text);text-align:center;border-top:2px solid rgba(0,0,0,.05);position:relative;overflow:hidden;isolation:isolate}
.contact-section .stitle{color:var(--dark)}
.contact-section .ssub{color:var(--muted);margin-left:auto;margin-right:auto}
.contact-row{display:flex;justify-content:center;gap:20px;margin-bottom:36px}
.contact-item{padding:20px 28px;border-radius:14px;background:#fff;border:1px solid rgba(0,0,0,.08);text-align:center;box-shadow:0 2px 12px rgba(0,0,0,.06)}
.contact-item-icon{font-size:20px;margin-bottom:6px}
.contact-item-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:3px}
.contact-item-val{font-size:13.5px;font-weight:600;color:var(--dark)}
.contact-item a{color:var(--navy);text-decoration:none}
footer{padding:20px 60px;background:var(--dark);display:flex;justify-content:space-between;align-items:center}
footer span{font-size:11px;color:rgba(255,255,255,.25)}
footer a{color:rgba(255,255,255,.4);text-decoration:none;font-size:11px}
.st-panel{padding-top:56px;min-height:100vh;display:flex;background:var(--off)}
.st-sidebar{width:220px;min-width:220px;background:var(--white);border-right:1px solid rgba(0,0,0,.06);display:flex;flex-direction:column;height:calc(100vh - 56px);position:sticky;top:56px}
.st-sidebar-head{padding:20px 20px 16px;border-bottom:1px solid rgba(0,0,0,.06)}
.st-sidebar-head h2{font-size:17px;font-weight:800;color:var(--navy)}
.st-sidebar-head p{font-size:10.5px;color:var(--muted);letter-spacing:.05em;text-transform:uppercase;margin-top:2px}
.st-nav-list{padding:12px 10px;flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:2px}
.st-nav-list button{display:flex;align-items:center;gap:9px;padding:10px 14px;border-radius:8px;border:none;background:transparent;color:var(--muted);cursor:pointer;font-size:12.5px;font-weight:500;font-family:inherit;text-align:left;transition:all .15s;width:100%}
.st-nav-list button:hover{background:rgba(10,36,99,.04)}
.st-nav-list button.active{background:rgba(10,36,99,.06);color:var(--navy);font-weight:700}
.st-nav-list button .icon{display:inline-flex;align-items:center;justify-content:center;width:22px;flex-shrink:0}
.st-nav-list .nav-group-label{padding:10px 14px 4px;font-size:10px;font-weight:700;color:var(--navy);letter-spacing:.06em;text-transform:uppercase;opacity:.5}
.st-nav-list button.sub{padding-left:32px;font-size:11.5px}
.st-main{flex:1;padding:36px 48px;overflow-y:auto;max-height:calc(100vh - 56px)}
.st-main .st-title{font-size:32px;font-weight:700;color:var(--navy-deep);margin-bottom:4px}
.st-main .st-sub{font-size:14px;color:var(--muted);margin-bottom:28px;line-height:1.6}
.tech-hero{display:flex;align-items:center;gap:32px;margin-bottom:32px;padding:32px;border-radius:16px;background:linear-gradient(135deg,var(--navy-deep),#142850);color:var(--white);position:relative;overflow:hidden}
.tech-hero::after{content:'';position:absolute;top:-40px;right:-40px;width:180px;height:180px;border-radius:50%;background:rgba(212,161,74,.06)}
.tech-hero-text{flex:1;position:relative;z-index:1}
.tech-hero-text h2{font-size:26px;font-weight:900;margin-bottom:6px;color:var(--white)}
.tech-hero-text p{font-size:13.5px;color:rgba(255,255,255,.55);line-height:1.6}
.tech-hero-visual{flex-shrink:0;width:160px;height:160px;display:flex;align-items:center;justify-content:center;position:relative;z-index:1;border-radius:12px;overflow:hidden}
.tech-hero-visual img{width:100%!important;height:100%!important;object-fit:cover!important;border-radius:12px}
.st-main .st-dim{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--navy);margin:32px 0 6px;padding-bottom:8px;border-bottom:2px solid var(--accent)}
.st-main .st-sec{font-size:10.5px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;margin-top:16px}
.st-main .st-grid{display:grid;gap:12px;margin-bottom:16px}
.st-main .st-grid-2{grid-template-columns:1fr 1fr}
.st-main .st-grid-3{grid-template-columns:1fr 1fr 1fr}
.st-main .st-card{background:var(--white);border:2px solid rgba(0,0,0,.05);border-radius:14px;padding:20px;transition:all .2s}
.st-main .st-card:hover{box-shadow:0 4px 16px rgba(0,0,0,.05)}
.st-main .st-card-accent{border-left:3px solid var(--accent)}
.st-main .st-card-blue{border-left:3px solid var(--blue)}
.st-main .st-card-green{border-left:3px solid var(--green)}
.st-main .st-card h4{font-size:15px;font-weight:800;color:var(--dark);margin-bottom:2px}
.st-main .st-card .sub{font-size:11.5px;color:var(--accent);font-style:italic;margin-bottom:6px}
.st-main .st-card p{font-size:12.5px;color:var(--muted);line-height:1.6}
.st-main .st-card .tag{display:inline-block;padding:2px 8px;border-radius:5px;font-size:9.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;margin-top:8px;margin-right:4px}
.st-main .tag-blue{background:rgba(30,86,160,.08);color:var(--blue);border:1px solid rgba(30,86,160,.15)}
.st-main .tag-green{background:rgba(42,157,110,.08);color:var(--green);border:1px solid rgba(42,157,110,.15)}
.st-main .tag-accent{background:rgba(212,161,74,.08);color:var(--accent);border:1px solid rgba(212,161,74,.15)}
.st-main .tag-red{background:rgba(220,60,60,.06);color:#c04040;border:1px solid rgba(220,60,60,.12)}
.st-main .tag-navy{background:rgba(10,36,99,.06);color:var(--navy);border:1px solid rgba(10,36,99,.1)}
.st-main .st-adv{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}
.st-main .st-adv-title{font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;margin-bottom:3px;color:var(--dark)}
.st-main .st-adv-text{font-size:11.5px;color:var(--muted);line-height:1.5}
.st-main .st-group{border:2px solid rgba(10,36,99,.1);border-radius:16px;overflow:hidden;margin-bottom:14px;background:var(--white)}
.st-main .st-group-head{background:var(--navy-deep);padding:18px 24px;color:var(--white)}
.st-main .st-group-head h4{font-size:17px;font-weight:800;color:var(--white);margin-bottom:2px}
.st-main .st-group-head .sub{color:var(--accent);font-size:12px;font-style:italic}
.st-main .st-group-head p{font-size:12px;color:rgba(255,255,255,.55);line-height:1.6;margin-top:6px}
.st-main .st-group-cols{display:grid;grid-template-columns:1fr 1fr}
.st-main .st-group-col{padding:20px 22px;border-right:1px solid rgba(0,0,0,.05)}
.st-main .st-group-col:last-child{border-right:none}
.st-main .st-group-col h5{font-size:14px;font-weight:800;color:var(--navy);margin-bottom:2px}
.st-main .st-group-col .sub{font-size:11.5px;color:var(--accent);font-style:italic;margin-bottom:6px}
.st-main .st-group-col p{font-size:12px;color:var(--muted);line-height:1.5}
.st-main .st-warn{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:6px;background:rgba(220,80,60,.06);border:1px solid rgba(220,80,60,.15);font-size:10.5px;font-weight:600;color:#c04040;margin-top:8px}
.st-main .st-feat{display:flex;align-items:start;gap:8px;margin-bottom:5px}
.st-main .st-feat-ck{color:var(--accent);font-size:12px;margin-top:1px;flex-shrink:0}
.st-main .st-feat-name{font-size:12.5px;font-weight:600;color:var(--dark)}
.st-main .st-feat-desc{font-size:12px;color:var(--muted)}
.st-main .st-arrow{text-align:center;margin:6px 0;font-size:16px;color:var(--muted);opacity:.4}
.st-main .st-branches{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;margin-top:12px}
.st-main .st-branch{background:var(--white);border:2px solid rgba(0,0,0,.05);border-radius:14px;padding:20px;border-top:3px solid var(--blue)}
.st-main .st-branch h5{font-size:13px;font-weight:800;color:var(--dark);margin-bottom:3px}
.st-main .st-branch .sub{font-size:11px;color:var(--muted);font-style:italic;margin-bottom:10px}
.st-main .st-branch p{font-size:11.5px;color:var(--muted);line-height:1.5}
.st-main .cfg-opt{background:var(--white);border:2px solid rgba(0,0,0,.06);border-radius:10px;padding:12px 16px;cursor:pointer;transition:all .15s}
.st-main .cfg-opt:hover{border-color:var(--blue)}
.st-main .cfg-opt.selected{border-color:var(--accent);background:rgba(212,161,74,.04);box-shadow:0 0 12px rgba(212,161,74,.08)}
.st-main .cfg-opt.disabled{opacity:.3;pointer-events:none}
.st-main .cfg-opt-label{font-size:13px;font-weight:700;color:var(--dark)}
.st-main .cfg-opt.selected .cfg-opt-label{color:var(--accent)}
.st-main .cfg-opt-desc{font-size:11px;color:var(--muted);margin-top:2px}
.st-main .cfg-chk{background:var(--white);border:2px solid rgba(0,0,0,.06);border-radius:10px;padding:12px 16px;cursor:pointer;transition:all .15s}
.st-main .cfg-chk:hover{border-color:var(--blue)}
.st-main .cfg-chk.checked{border-color:var(--accent);background:rgba(212,161,74,.04)}
.st-main .cfg-chk-box{width:16px;height:16px;border:2px solid var(--muted);border-radius:4px;display:inline-flex;align-items:center;justify-content:center;margin-right:8px;font-size:10px;vertical-align:middle}
.st-main .cfg-chk.checked .cfg-chk-box{border-color:var(--accent);background:var(--accent);color:var(--white)}
.st-main .st-progress{background:rgba(212,161,74,.06);border:1px solid rgba(212,161,74,.15);border-radius:12px;padding:14px 20px;margin-bottom:24px;display:flex;justify-content:space-between;align-items:center}
.st-main .st-progress-label{font-size:13px;font-weight:700;color:var(--accent)}
.st-main .st-progress-bar{width:140px;height:6px;border-radius:3px;background:rgba(0,0,0,.06)}
.st-main .st-progress-fill{height:6px;border-radius:3px;background:var(--accent);transition:width .3s}
.st-main .st-step{font-size:14px;font-weight:800;color:var(--navy);margin:22px 0 10px}
.st-main .cfg-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.st-main .cfg-item{border-radius:8px;padding:10px 12px;background:rgba(212,161,74,.04);border:1px solid rgba(212,161,74,.1)}
.st-main .cfg-item-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-bottom:2px;color:var(--accent)}
.st-main .cfg-item-value{font-size:11px;color:var(--muted);font-family:'Manrope',sans-serif}
.img-lightbox{display:none;position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:99999;align-items:center;justify-content:center;cursor:zoom-out;backdrop-filter:blur(6px)}
.img-lightbox.open{display:flex}
.img-lightbox img{max-width:90vw;max-height:90vh;object-fit:contain;filter:drop-shadow(0 12px 40px rgba(0,0,0,.6));animation:lbIn .25s ease}
@keyframes lbIn{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}
.cfg-preview{position:fixed;right:24px;top:80px;width:264px;z-index:100;opacity:0;transform:translateX(20px);transition:opacity .3s,transform .3s;pointer-events:none}
.cfg-preview.visible{opacity:1;transform:translateX(0);pointer-events:auto}
.cfg-preview-inner{position:relative;width:100%;padding-top:56.25%;overflow:hidden;border-radius:10px;background:#e8e8e8;box-shadow:0 8px 32px rgba(10,36,99,.2);border:2px solid rgba(10,36,99,.1)}
.cfg-preview-inner img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}
.cfg-preview-label{text-align:center;margin-top:6px;font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
@media(max-width:1100px){.cfg-preview{display:none}}
.quote-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(10,36,99,.45);z-index:9999;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.quote-overlay.open{display:flex}
.quote-modal{background:var(--white);border-radius:16px;padding:28px 32px;max-width:560px;width:90%;max-height:85vh;overflow-y:auto;box-shadow:0 20px 60px rgba(10,36,99,.2)}
.quote-modal h4{font-size:18px;color:var(--navy);margin-bottom:4px}
.quote-modal .qsub{font-size:12.5px;color:var(--muted);margin-bottom:18px}
.quote-modal .cfg-recap{margin-bottom:18px;padding:14px;background:var(--off);border-radius:10px;border:1px solid rgba(10,36,99,.06)}
.quote-modal .cfg-recap-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--navy);margin-bottom:8px}
.quote-modal .cfg-recap-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px 10px}
.quote-modal .cfg-recap-item{font-size:11px;color:var(--muted)}
.quote-modal .cfg-recap-item strong{color:var(--navy);font-weight:700}
.quote-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.quote-field{display:flex;flex-direction:column;gap:3px}
.quote-field.full{grid-column:1/-1}
.quote-field label{font-size:11px;font-weight:700;color:var(--navy);letter-spacing:.04em}
.quote-field input,.quote-field select,.quote-field textarea{padding:8px 12px;border:1px solid rgba(10,36,99,.12);border-radius:8px;font-size:13px;font-family:Manrope,sans-serif;color:var(--navy);background:var(--off);outline:none;transition:border .2s}
.quote-field input:focus,.quote-field select:focus,.quote-field textarea:focus{border-color:var(--blue)}
.quote-field textarea{resize:vertical;min-height:60px}
.quote-actions{display:flex;gap:10px;margin-top:16px}
.quote-btn{flex:1;padding:12px 28px;background:var(--navy);color:var(--white);border:none;border-radius:10px;font-size:14px;font-weight:700;font-family:Manrope,sans-serif;cursor:pointer;transition:background .2s}
.quote-btn:hover{background:var(--blue)}
.quote-btn-cancel{flex:0;padding:12px 20px;background:transparent;color:var(--muted);border:1px solid rgba(10,36,99,.12);border-radius:10px;font-size:13px;font-family:Manrope,sans-serif;cursor:pointer}
.quote-btn-cancel:hover{border-color:var(--navy);color:var(--navy)}
.quote-ok{display:none;margin-top:10px;padding:12px;background:rgba(42,157,110,.08);border:1px solid rgba(42,157,110,.2);border-radius:8px;color:var(--navy);font-size:13px;text-align:center}
.quote-cta{display:inline-flex;align-items:center;gap:8px;margin-top:14px;padding:12px 24px;background:var(--navy);color:var(--white);border:none;border-radius:10px;font-size:14px;font-weight:700;font-family:Manrope,sans-serif;cursor:pointer;transition:background .2s}
.quote-cta:hover{background:var(--blue)}
.st-main .st-highlight{border:2px solid var(--accent);box-shadow:0 0 16px rgba(212,161,74,.06);border-radius:14px;padding:20px;background:var(--white);margin-bottom:14px}
.st-main .st-cat-section{margin-bottom:20px}
.st-main .st-cat-head{font-size:13px;font-weight:700;color:var(--navy);margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid rgba(0,0,0,.06)}
.st-main .st-cat-row{display:flex;justify-content:space-between;align-items:center;padding:8px 14px;border-radius:6px;font-size:12.5px}
.st-main .st-cat-row:nth-child(even){background:rgba(0,0,0,.02)}
.st-main .st-cat-name{color:var(--text)}
.st-main .st-cat-price{font-family:'Manrope',sans-serif;color:var(--muted);font-size:11px}
.st-main .st-cat-upgrade{font-size:10px;font-weight:700;color:var(--accent);letter-spacing:.08em;text-transform:uppercase;margin:8px 0 4px;padding:4px 14px}
@media(max-width:1080px){
.lp-section{padding:72px 32px}.hero{grid-template-columns:1fr;padding:100px 32px 60px}
.hero-visual{justify-self:start;margin-top:40px}.hero-img-wrap{width:100%;max-width:440px}
.hero h1{font-size:36px}
.tech-grid,.up-cols,.how-grid,.pkg-grid,.sup-grid,.deeper-grid{grid-template-columns:1fr 1fr}
.topnav{padding:0 24px}.st-sidebar{display:none}
.uc-grid{grid-template-columns:1fr 1fr}.app-gallery{grid-template-columns:1fr 1fr;padding:32px}
.team-grid{grid-template-columns:repeat(3,1fr)}.cust-logos{grid-template-columns:repeat(4,1fr)}
.cust-map-grid{grid-template-columns:repeat(3,1fr)}.comp-values{grid-template-columns:1fr 1fr}
.trust-logos{gap:24px}
}
@media(max-width:640px){
.hero h1{font-size:28px}
.tech-grid,.up-cols,.how-grid,.pkg-grid,.sup-grid,.deeper-grid,.contact-row{grid-template-columns:1fr;flex-direction:column}
.hero-stats{flex-wrap:wrap;gap:20px}
.uc-grid,.app-gallery{grid-template-columns:1fr}.team-grid{grid-template-columns:1fr 1fr}
.cust-logos{grid-template-columns:repeat(3,1fr)}.cust-map-grid{grid-template-columns:1fr 1fr}
.comp-values{grid-template-columns:1fr}.trust-stats{gap:24px}.app-filters{flex-wrap:wrap}
.trust-logos{gap:16px}.trust-logos span{font-size:12px}
}

#cfg-visual-system{width:100%;box-sizing:border-box;}
.sysvis-img{width:100%;height:auto;display:block;border-radius:8px;}
.sysvis-progress-wrap{margin-bottom:14px;}
.sysvis-progress-label{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;}
.sysvis-missing-txt{font-size:11px;color:#ef4444;font-weight:600;}
.sysvis-pct{font-size:11px;font-weight:700;color:#6b7280;}
.sysvis-progress-bg{height:6px;background:#e5e7eb;border-radius:99px;overflow:hidden;}
.sysvis-progress-bar{height:100%;background:linear-gradient(90deg,#3b4fc8,#6875f5);border-radius:99px;transition:width .3s ease;}
.sysvis-preview-placeholder{width:100%;height:220px;background:linear-gradient(135deg,#f0f2ff 0%,#e8eaf6 100%);border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;border:2px dashed #c7d0f8;}
.sysvis-preview-label{font-size:22px;font-weight:900;color:#3b4fc8;letter-spacing:.15em;opacity:.4;}
.sysvis-preview-sub{font-size:12px;color:#6b7280;text-align:center;max-width:240px;}

/* v37 Phase A — Editorial Industrial */
@keyframes heroReveal{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@media(prefers-reduced-motion:reduce){
  .hero-eyebrow,.hero h1,.hero-desc,.hero-buttons,.hero-stats{animation:none!important}
}
.hero-eyebrow{font-family:'Manrope',sans-serif;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:32px;display:flex;align-items:center;gap:14px;animation:heroReveal .8s ease-out .1s backwards}
.hero-eyebrow::before{content:'';display:inline-block;width:24px;height:1px;background:var(--accent);opacity:.8;vertical-align:middle}
.hero h1{animation:heroReveal .8s ease-out .3s backwards}
.hero-desc{animation:heroReveal .8s ease-out .5s backwards}
.hero-buttons{animation:heroReveal .8s ease-out .7s backwards}
.hero-stats{animation:heroReveal .8s ease-out .9s backwards}
.section-number{font-family:'Manrope',sans-serif;font-size:14px;font-weight:700;letter-spacing:.08em;color:var(--accent);margin-bottom:24px;display:flex;align-items:center;gap:12px}
.section-number::after{content:'';height:1px;width:48px;background:currentColor;opacity:.3}

/* v39 — Character Anchoring */
.section-number-giant{position:absolute;top:40px;right:60px;font-family:'Manrope',sans-serif;font-size:220px;font-weight:700;line-height:1;color:currentColor;opacity:.04;pointer-events:none;user-select:none;letter-spacing:-.05em;z-index:-1}
section[style*="background:rgba(6,22,64"] .section-number-giant,
section[style*="background:#0D1F3C"] .section-number-giant{opacity:.07;color:#fff}
.grain-overlay{position:absolute;inset:0;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='noise'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/></svg>");mix-blend-mode:multiply;pointer-events:none;z-index:-1;opacity:.6}
@media(max-width:1080px){.section-number-giant{font-size:140px;top:28px;right:32px}}
@media(max-width:640px){.section-number-giant{font-size:90px;top:20px;right:16px}}

/* ===== Technology section v40 redesign ===== */
.tech-v40-intro{max-width:820px;margin-bottom:48px}
.tech-v40-intro .philo-line{font-size:17px;color:rgba(255,255,255,.72);line-height:1.7;margin-bottom:14px}
.tech-v40-intro .philo-line strong{color:var(--white);font-weight:600}
.tech-v40-intro .philo-tagline{font-family:'Manrope',sans-serif;font-size:13px;color:var(--accent);letter-spacing:.04em}
.tech-section-v40 .stitle,.tech-section-v40 h2{color:var(--white)}
.tech-tabs-wrap{display:flex;gap:0;border-bottom:1px solid rgba(255,255,255,.12);margin-bottom:36px}
.tech-tab-btn{flex:1;padding:20px 28px;background:none;border:none;border-bottom:3px solid transparent;font-family:'Manrope',sans-serif;font-size:15px;font-weight:600;color:rgba(255,255,255,.45);cursor:pointer;transition:all .25s;text-align:left;display:flex;flex-direction:column;gap:4px}
.tech-tab-btn small{font-family:'Manrope',sans-serif;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.35);transition:color .25s}
.tech-tab-btn:hover{color:rgba(255,255,255,.85)}
.tech-tab-btn.active{color:var(--white);border-bottom-color:var(--accent)}
.tech-tab-btn.active small{color:var(--accent)}
.tech-panel{display:none;animation:techFade .4s ease-out}
.tech-panel.active{display:block}
@keyframes techFade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.tech-panel-grid{display:grid;grid-template-columns:1fr 320px;gap:48px;align-items:start}
.tech-panel h3{font-size:28px;font-weight:700;color:var(--white);margin-bottom:14px;letter-spacing:-.5px}
.tech-panel-lede{font-size:16px;color:rgba(255,255,255,.75);line-height:1.7;margin-bottom:28px}
.tech-panel-label{font-family:'Manrope',sans-serif;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:10px}
.tech-list{list-style:none;padding:0;margin-bottom:28px}
.tech-list li{position:relative;padding:10px 0 10px 28px;font-size:14px;color:rgba(255,255,255,.82);border-bottom:1px solid rgba(255,255,255,.08);line-height:1.6}
.tech-list.limits li::before{content:'−';position:absolute;left:0;top:10px;width:18px;height:18px;background:rgba(255,255,255,.08);color:rgba(255,255,255,.55);border-radius:50%;font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1}
.tech-list.wins li::before{content:'✓';position:absolute;left:0;top:10px;width:18px;height:18px;background:var(--accent);color:#fff;border-radius:50%;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1}
.tech-visual{background:transparent;border-radius:0;padding:20px;min-height:320px;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative}
.tech-visual::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(227,83,54,.10) 0%,rgba(27,64,128,.06) 40%,transparent 70%);z-index:0;pointer-events:none}
.tech-visual img{position:relative;z-index:1;max-width:240px;height:auto;object-fit:contain;filter:drop-shadow(0 20px 40px rgba(0,0,0,.4))}
.tech-visual-caption{position:relative;z-index:1;color:rgba(255,255,255,.5);font-family:'Manrope',sans-serif;font-size:11px;letter-spacing:.08em;text-transform:uppercase}
.tech-philo-box{margin-top:40px;padding:24px 28px;background:rgba(255,255,255,.04);color:#fff;border-radius:0 8px 8px 0;border-left:3px solid var(--accent)}
.tech-philo-box-label{font-family:'Manrope',sans-serif;font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:10px}
.tech-philo-box-text{font-size:16px;line-height:1.6;color:rgba(255,255,255,.88)}
.tech-philo-box-text strong{color:#fff;font-weight:600}
.tech-ctas{margin-top:32px;display:flex;gap:12px}
.tech-ctas .btn-ghost{border:1px solid rgba(255,255,255,.25);color:var(--white)}
.tech-ctas .btn-ghost:hover{border-color:var(--accent);color:var(--accent)}
.tech-section-v40 .section-number-giant{color:rgba(255,255,255,.04)}
@media(max-width:900px){.tech-panel-grid{grid-template-columns:1fr}.tech-visual{min-height:260px}.tech-tab-btn{padding:14px 16px;font-size:14px}}

/* ===== Section 01 Complete Ecosystem v41 redesign ===== */
.sec01-v41{position:relative;overflow:hidden;isolation:isolate;padding:100px 40px}
.sec01-v41 .sec01-inner{max-width:1280px;margin:0 auto;position:relative;z-index:2}
.sec01-hero{display:grid;grid-template-columns:1fr 1.3fr;gap:48px;align-items:center;margin-top:32px}
.sec01-text-col{max-width:580px}
.sec01-image-col img{width:100%;height:auto;display:block}
.sec01-v41 .sec01-title{font-size:64px;font-weight:700;letter-spacing:-1.5px;line-height:1;margin-bottom:20px;color:#ffffff}
.sec01-v41 .sec01-sub{color:rgba(255,255,255,.72);font-size:17px;line-height:1.6;max-width:520px;margin-bottom:0}
.sec01-pills{margin-top:48px;padding-top:32px;border-top:1px solid rgba(255,255,255,.08);display:flex;flex-wrap:wrap;gap:10px}
.sec01-pill{padding:9px 16px;border:1px solid rgba(255,255,255,.12);border-radius:50px;display:inline-flex;align-items:center;gap:10px;text-decoration:none;transition:all .2s ease;white-space:nowrap;cursor:pointer}
.sec01-pill:hover{border-color:var(--accent);background:rgba(227,83,54,.08)}
.sec01-pill .pill-name{font-family:'Manrope',sans-serif;font-size:12px;font-weight:700;color:var(--accent);letter-spacing:.04em}
.sec01-pill .pill-sep{width:3px;height:3px;background:rgba(255,255,255,.25);border-radius:50%;flex-shrink:0}
.sec01-pill .pill-desc{font-size:13px;color:rgba(255,255,255,.72)}
.sec01-footer-cta{margin-top:48px;padding-top:28px;border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.sec01-footer-cta-text{color:rgba(255,255,255,.7);font-size:14px}
.sec01-footer-cta-link{color:var(--accent);font-weight:600;text-decoration:none;font-size:15px;display:inline-flex;align-items:center;gap:6px;transition:gap .2s}
.sec01-footer-cta-link:hover{gap:10px}
@media(max-width:900px){.sec01-hero{grid-template-columns:1fr;gap:24px}.sec01-v41 .sec01-title{font-size:40px}.sec01-text-col{max-width:100%}.sec01-pills{justify-content:flex-start}}
/* ===== Section 02 Trust v43 redesign ===== */
.sec02-v43{background:var(--off);color:var(--text);padding:80px 40px;position:relative;overflow:hidden;isolation:isolate}
.sec02-v43 .sec02-inner{max-width:1280px;margin:0 auto;position:relative;z-index:2}
.sec02-v43 .sec02-title{font-size:42px;font-weight:700;color:var(--navy-deep);letter-spacing:-.8px;line-height:1.1;margin-bottom:16px;max-width:900px}
.sec02-v43 .sec02-sub{color:var(--muted);font-size:16px;line-height:1.6;max-width:680px;margin-bottom:48px}
.sec02-carousel{overflow:hidden;margin:0 -40px;padding:0 40px;position:relative;mask-image:linear-gradient(to right,transparent 0%,black 5%,black 95%,transparent 100%);-webkit-mask-image:linear-gradient(to right,transparent 0%,black 5%,black 95%,transparent 100%)}
.sec02-row{display:flex;gap:20px;width:max-content;animation:sec02ScrollLeft 40s linear infinite;margin-bottom:20px}
.sec02-row.reverse{animation:sec02ScrollRight 40s linear infinite}
.sec02-row:hover,.sec02-row.reverse:hover{animation-play-state:paused}
@keyframes sec02ScrollLeft{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes sec02ScrollRight{from{transform:translateX(-50%)}to{transform:translateX(0)}}
.sec02-logo{min-width:160px;height:80px;flex-shrink:0;display:flex;align-items:center;justify-content:center;padding:12px 20px;background:rgba(13,31,60,.03);border-radius:8px;border:1px solid transparent;transition:all .25s;cursor:pointer}
.sec02-logo:hover{background:rgba(13,31,60,.06);border-color:rgba(13,31,60,.1)}
.sec02-logo img{max-width:100%;max-height:100%;object-fit:contain;filter:grayscale(20%);opacity:.85;transition:all .25s}
.sec02-logo:hover img{filter:grayscale(0%);opacity:1}
.sec02-stats{margin-top:64px;padding-top:40px;border-top:1px solid rgba(13,31,60,.1);display:grid;grid-template-columns:repeat(3,1fr);gap:48px}
.sec02-stat{display:flex;flex-direction:column;gap:6px}
.sec02-stat-value{font-size:48px;font-weight:700;color:var(--navy-deep);letter-spacing:-1px;line-height:1}
.sec02-stat-label{font-family:'Manrope',sans-serif;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.sec02-cta{margin-top:48px;padding-top:28px;border-top:1px solid rgba(13,31,60,.08);display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.sec02-cta-text{color:var(--muted);font-size:14px}
.sec02-cta-link{color:var(--accent);font-weight:600;text-decoration:none;font-size:15px;display:inline-flex;align-items:center;gap:6px;transition:gap .2s}
.sec02-cta-link:hover{gap:10px}
@media(max-width:900px){.sec02-v43 .sec02-title{font-size:30px}.sec02-stats{grid-template-columns:1fr;gap:24px}.sec02-stat-value{font-size:36px}.sec02-logo{min-width:120px;height:60px}}
@media(prefers-reduced-motion:reduce){.sec02-row,.sec02-row.reverse{animation:none}}
/* ===== Section 04 Upgrades v45 (interactive timeline) ===== */
.sec04-v45{background:var(--off);color:var(--text);padding:80px 40px;position:relative;overflow:hidden;isolation:isolate}
.sec04-v45 .sec04-inner{max-width:1280px;margin:0 auto;position:relative;z-index:2}
.sec04-v45 .sec04-title{font-size:44px;font-weight:700;color:var(--navy-deep);letter-spacing:-.8px;line-height:1.1;margin-bottom:18px;max-width:900px}
.sec04-v45 .sec04-sub{color:var(--muted);font-size:17px;line-height:1.65;max-width:720px;margin-bottom:32px}
.sec04-v45 .sec04-sub em{font-family:'Manrope',sans-serif;font-size:14px;font-style:normal;color:var(--accent);letter-spacing:.04em}
.sec04-summary{display:flex;align-items:center;gap:14px;padding:14px 20px;background:var(--white);border-radius:50px;box-shadow:0 2px 12px rgba(13,31,60,.06);margin-bottom:48px;flex-wrap:wrap}
.sec04-summary-label{font-family:'Manrope',sans-serif;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.sec04-badges{display:flex;gap:6px;flex-wrap:wrap}
.sec04-badge{padding:6px 12px;border-radius:50px;font-family:'Manrope',sans-serif;font-size:11px;font-weight:700;letter-spacing:.05em;transition:all .3s}
.sec04-badge.base{background:var(--navy-deep);color:var(--white)}
.sec04-badge.upgrade{background:rgba(13,31,60,.06);color:rgba(13,31,60,.35);border:1px dashed rgba(13,31,60,.2)}
.sec04-badge.upgrade.active{background:var(--accent);color:var(--white);border:1px solid var(--accent);border-style:solid}
.sec04-reset{margin-left:auto;background:transparent;border:none;cursor:pointer;color:var(--muted);font-family:'Manrope',sans-serif;font-size:11px;letter-spacing:.08em;text-transform:uppercase;padding:6px 10px;transition:color .2s}
.sec04-reset:hover{color:var(--accent)}
.sec04-reset.hidden{display:none}
.sec04-timeline-wrap{position:relative;padding:0 0 40px}
.sec04-timeline-line{position:absolute;top:22px;left:7%;right:7%;height:2px;background:rgba(13,31,60,.1);z-index:0}
.sec04-timeline{display:grid;grid-template-columns:1fr 1fr 1fr;gap:28px;position:relative;z-index:1}
.sec04-step{display:flex;flex-direction:column;align-items:center}
.sec04-step-number{width:44px;height:44px;border-radius:50%;background:var(--white);border:3px solid var(--accent);display:flex;align-items:center;justify-content:center;font-family:'Manrope',sans-serif;font-size:16px;font-weight:700;color:var(--accent);margin-bottom:24px;position:relative;z-index:2;transition:all .25s;user-select:none}
.sec04-step.optional .sec04-step-number{background:var(--white);border-color:rgba(13,31,60,.2);color:rgba(13,31,60,.5);cursor:pointer}
.sec04-step.optional .sec04-step-number:hover{border-color:var(--accent);color:var(--accent);transform:scale(1.08)}
.sec04-step.optional.active .sec04-step-number{background:var(--accent);border-color:var(--accent);color:var(--white);cursor:pointer}
.sec04-step.optional.active .sec04-step-number:hover{background:#c5371b;border-color:#c5371b;transform:scale(1.08)}
.sec04-card{background:var(--white);border-radius:12px;overflow:hidden;box-shadow:0 4px 16px rgba(13,31,60,.06);width:100%;display:flex;flex-direction:column;border:2px solid transparent;transition:all .3s}
.sec04-step.optional.active .sec04-card{border-color:var(--accent);box-shadow:0 8px 28px rgba(227,83,54,.15)}
.sec04-card-photo{width:100%;aspect-ratio:4/3;overflow:hidden;background:#0D1F3C}
.sec04-card-photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s}
.sec04-card:hover .sec04-card-photo img{transform:scale(1.04)}
.sec04-card-body{padding:24px;display:flex;flex-direction:column;gap:12px;flex:1}
.sec04-card-label{font-family:'Manrope',sans-serif;font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.sec04-step.optional .sec04-card-label{color:var(--accent)}
.sec04-card-name{font-size:22px;font-weight:700;color:var(--navy-deep);letter-spacing:-.3px;line-height:1.15}
.sec04-card-desc{font-size:13px;color:var(--muted);line-height:1.55}
.sec04-card-actions{display:flex;gap:10px;align-items:center;padding-top:12px;margin-top:auto;border-top:1px solid rgba(13,31,60,.08);flex-wrap:wrap}
.sec04-pill-included{font-family:'Manrope',sans-serif;font-size:11px;color:var(--muted);letter-spacing:.05em;padding:9px 14px;background:rgba(13,31,60,.04);border-radius:50px}
.sec04-btn-add{background:var(--accent);color:var(--white);border:1px solid var(--accent);border-radius:50px;padding:9px 18px;font-weight:600;font-size:13px;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:5px;font-family:'Manrope',sans-serif}
.sec04-btn-add:hover{background:#c5371b;border-color:#c5371b}
.sec04-step.active .sec04-btn-add{background:transparent;color:var(--accent)}
.sec04-step.active .sec04-btn-add:hover{background:rgba(227,83,54,.08)}
.sec04-btn-add .icon::before{content:'+';font-weight:700;font-size:16px;line-height:1}
.sec04-step.active .sec04-btn-add .icon::before{content:'\2713';font-size:13px}
.sec04-btn-add .label::after{content:'Add'}
.sec04-step.active .sec04-btn-add .label::after{content:'Added'}
.sec04-btn-more{background:transparent;border:none;cursor:pointer;color:var(--muted);font-weight:600;font-size:13px;display:inline-flex;align-items:center;gap:5px;padding:8px 12px;transition:color .2s;font-family:'Manrope',sans-serif;margin-left:auto}
.sec04-btn-more:hover{color:var(--accent)}
.sec04-btn-more::after{content:'\2192';transition:transform .25s}
.sec04-btn-more.open::after{transform:rotate(90deg)}
.sec04-details-stack{margin-top:32px;display:flex;flex-direction:column;gap:16px}
.sec04-panel{background:var(--white);border-radius:12px;padding:32px 36px;box-shadow:0 4px 16px rgba(13,31,60,.04);border-left:3px solid var(--accent);display:none;animation:sec04FadeIn .35s ease}
.sec04-panel.visible{display:block}
@keyframes sec04FadeIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
.sec04-panel-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px}
.sec04-panel-label{font-family:'Manrope',sans-serif;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent)}
.sec04-panel-close{background:transparent;border:1px solid rgba(13,31,60,.15);border-radius:50%;width:32px;height:32px;cursor:pointer;color:var(--muted);font-size:16px;padding:0;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}
.sec04-panel-close:hover{background:var(--accent);color:var(--white);border-color:var(--accent)}
.sec04-capabilities{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-bottom:24px}
.sec04-capability{display:flex;flex-direction:column;gap:6px}
.sec04-capability-label{font-family:'Manrope',sans-serif;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent)}
.sec04-capability-name{font-size:17px;font-weight:700;color:var(--navy-deep)}
.sec04-capability-desc{font-size:14px;color:var(--muted);line-height:1.6}
.sec04-panel-profiles{padding-top:20px;border-top:1px solid rgba(13,31,60,.08);display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.sec04-profiles-label{font-family:'Manrope',sans-serif;font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.sec04-profile-tags{display:flex;flex-wrap:wrap;gap:6px}
.sec04-profile-tag{padding:5px 11px;background:rgba(227,83,54,.08);color:var(--accent);border-radius:50px;font-family:'Manrope',sans-serif;font-size:10px;font-weight:700;letter-spacing:.05em}
.sec04-footer{margin-top:48px;padding-top:28px;border-top:1px solid rgba(13,31,60,.1);display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.sec04-footer-text{color:var(--muted);font-size:14px}
.sec04-footer-link{color:var(--accent);font-weight:600;text-decoration:none;font-size:15px}
.sec04-footer-link:hover{text-decoration:underline}
@media(max-width:900px){.sec04-timeline{grid-template-columns:1fr}.sec04-timeline-line{display:none}.sec04-capabilities{grid-template-columns:1fr}.sec04-v45 .sec04-title{font-size:32px}.sec04-card-actions{flex-wrap:wrap}.sec04-btn-more{margin-left:0}}

/* === v47 AMBER ACCENT OVERRIDES === */
/* Logo stays white (typographic mark, not chromatic accent) */
.topnav-logo,.topnav-logo span{color:var(--white)}
/* Topnav CTA: amber pill */
.topnav-cta{background:var(--accent);color:var(--navy-deep);font-family:'Manrope',sans-serif;font-weight:700}
.topnav-cta:hover{background:#E0B560;box-shadow:0 4px 16px rgba(212,161,74,.35);transform:translateY(-1px)}
/* Topnav nav buttons: support full-length Configure label */
.topnav-btn{font-size:12.5px;padding:8px 11px;white-space:nowrap}
/* Hero accent word now amber (legible on dark navy) */
.hero h1 .accent-word{color:var(--accent)}
/* btn-primary on dark hero: amber bg + navy text for contrast */
.hero .btn-primary{background:var(--accent);color:var(--navy-deep);border-color:var(--accent)}
.hero .btn-primary:hover{background:#E0B560;border-color:#E0B560}
/* btn-primary default (light bg) keeps amber */
.btn-primary{color:var(--navy-deep)}
/* Package featured button on dark gradient bg */
.pkg-btn-primary{background:var(--accent);color:var(--navy-deep)}
.pkg-btn-primary:hover{background:#E0B560}
/* App filter active: amber bg + navy text */
.app-filter:hover,.app-filter.active{background:var(--accent);color:var(--navy-deep);border-color:var(--accent)}
/* Stat numbers on dark: amber pops */
.cust-stat-num{color:var(--accent)}
/* Comp-since pill on dark navy: amber-tinted */
.comp-hero .comp-since{background:rgba(212,161,74,.12);border:1px solid rgba(212,161,74,.30);color:var(--accent)}
/* SVG checkmark stroke (still uses literal hex in pkg.feat) — already converted to amber via H2 above */

/* === v47 CONFIG OPTION CARD TOOLTIPS (replaces v46 ? icons) === */
.cfg-opt{position:relative}
.cfg-opt[data-tip]::before{content:attr(data-tip);position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%);background:var(--navy-deep);color:#fff;padding:10px 14px;border-radius:8px;font-size:12px;font-weight:400;width:240px;line-height:1.55;opacity:0;pointer-events:none;transition:opacity .15s;box-shadow:0 8px 28px rgba(0,0,0,.30);text-align:left;text-transform:none;letter-spacing:0;z-index:9999;white-space:normal;font-family:'Manrope',sans-serif}
.cfg-opt[data-tip]::after{content:'';position:absolute;top:calc(100% + 4px);left:50%;transform:translateX(-50%);border:6px solid transparent;border-bottom-color:var(--navy-deep);opacity:0;transition:opacity .15s;z-index:9999;pointer-events:none}
.cfg-opt[data-tip]:hover::before,.cfg-opt[data-tip]:hover::after,.cfg-opt[data-tip].tip-active::before,.cfg-opt[data-tip].tip-active::after{opacity:1}
.cfg-opt[data-tip]:hover::before{pointer-events:auto}
/* CHK (checkbox-style) options also get tooltips */
.cfg-chk{position:relative}
.cfg-chk[data-tip]::before{content:attr(data-tip);position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%);background:var(--navy-deep);color:#fff;padding:10px 14px;border-radius:8px;font-size:12px;font-weight:400;width:240px;line-height:1.55;opacity:0;pointer-events:none;transition:opacity .15s;box-shadow:0 8px 28px rgba(0,0,0,.30);text-align:left;text-transform:none;letter-spacing:0;z-index:9999;white-space:normal;font-family:'Manrope',sans-serif}
.cfg-chk[data-tip]::after{content:'';position:absolute;top:calc(100% + 4px);left:50%;transform:translateX(-50%);border:6px solid transparent;border-bottom-color:var(--navy-deep);opacity:0;transition:opacity .15s;z-index:9999;pointer-events:none}
.cfg-chk[data-tip]:hover::before,.cfg-chk[data-tip]:hover::after{opacity:1}

/* === v47 ST-STEP TECH-LINK ARROW (replaces v46 ? at section level) === */
.st-step{display:flex;align-items:center;gap:12px;justify-content:space-between}
.cfg-tech-link{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--accent);text-decoration:none;background:none;border:none;cursor:pointer;font-family:'Manrope',sans-serif;padding:4px 0;transition:opacity .15s}
.cfg-tech-link:hover{opacity:.7}
.cfg-tech-link::after{content:'\2197';font-size:13px}

/* === v47 CONTACT POPUP (matches quote-modal style) === */
.contact-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(13,31,60,.45);z-index:9999;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.contact-overlay.open{display:flex}
.contact-modal{background:var(--white);border-radius:16px;padding:28px 32px;max-width:560px;width:90%;max-height:85vh;overflow-y:auto;box-shadow:0 20px 60px rgba(13,31,60,.2)}
.contact-modal h4{font-size:18px;color:var(--navy-deep);margin-bottom:4px}
.contact-modal .csub{font-size:13px;color:var(--muted);margin-bottom:20px;line-height:1.5}
.contact-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:18px}
.contact-form-grid .full{grid-column:1/-1}
.contact-field label{display:block;font-size:11px;font-weight:700;color:var(--navy-deep);margin-bottom:6px;letter-spacing:.04em;text-transform:uppercase}
.contact-field input,.contact-field select,.contact-field textarea{width:100%;padding:9px 12px;border:1px solid rgba(13,31,60,.14);border-radius:8px;font-size:13px;font-family:'Manrope',sans-serif;color:var(--navy-deep);background:var(--off);outline:none;transition:border .2s}
.contact-field input:focus,.contact-field select:focus,.contact-field textarea:focus{border-color:var(--accent)}
.contact-field textarea{resize:vertical;min-height:90px}
.contact-actions{display:flex;gap:10px;justify-content:flex-end;align-items:center}
.contact-btn-cancel{padding:11px 20px;background:transparent;color:var(--muted);border:1px solid rgba(13,31,60,.14);border-radius:10px;font-size:13px;font-family:'Manrope',sans-serif;cursor:pointer;font-weight:600}
.contact-btn-submit{padding:11px 24px;background:var(--accent);color:var(--navy-deep);border:none;border-radius:10px;font-size:14px;font-weight:700;font-family:'Manrope',sans-serif;cursor:pointer;transition:all .2s}
.contact-btn-submit:hover{background:#E0B560}
.contact-ok{display:none;padding:14px 16px;background:rgba(42,157,110,.10);color:#1d7a52;border-radius:10px;font-size:13px;margin-top:14px;border:1px solid rgba(42,157,110,.25)}
.contact-ok.show{display:block}
@media(max-width:560px){.contact-form-grid{grid-template-columns:1fr}}


/* === v48 USE CASE BADGES (multi-tag) === */
.app-card-cats{position:absolute;top:12px;left:12px;display:flex;gap:5px;flex-wrap:wrap;max-width:calc(100% - 24px)}
.app-card-cat-badge{padding:4px 9px;border-radius:5px;background:rgba(13,31,60,.85);color:var(--accent);font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;backdrop-filter:blur(6px)}

/* === v48 PROJECT POPUP — A4 portrait === */
.proj-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(13,31,60,.55);z-index:10000;align-items:flex-start;justify-content:center;backdrop-filter:blur(6px);overflow-y:auto;padding:32px 16px}
.proj-overlay.open{display:flex}
.proj-modal{background:#fff;border-radius:12px;width:100%;max-width:720px;box-shadow:0 24px 80px rgba(13,31,60,.30);position:relative;font-family:'Manrope',sans-serif;overflow:hidden;margin-bottom:32px}
/* A4 ratio reference: 1:1.414 portrait. 720px wide → ~1018px tall content target. */
.proj-close{position:absolute;top:14px;right:14px;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.95);border:none;font-size:20px;color:var(--navy-deep);cursor:pointer;z-index:5;box-shadow:0 2px 10px rgba(0,0,0,.15);display:flex;align-items:center;justify-content:center;font-weight:600}
.proj-close:hover{background:#fff;transform:scale(1.05)}
.proj-cover{width:100%;aspect-ratio:16/9;background-size:cover;background-position:center;background-color:var(--navy-deep)}
.proj-body{padding:32px 40px}
@media(max-width:560px){.proj-body{padding:24px 22px}}
.proj-meta-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:14px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
.proj-meta-row .proj-tag{padding:3px 9px;border-radius:5px;background:rgba(212,161,74,.14);color:var(--accent);font-weight:700}
.proj-meta-row .sep{color:rgba(0,0,0,.20)}
.proj-title{font-size:30px;font-weight:800;color:var(--navy-deep);letter-spacing:-.02em;line-height:1.15;margin-bottom:6px}
.proj-claim{font-size:13px;color:var(--accent);font-style:italic;margin-bottom:20px;font-weight:500}
.proj-divider{height:1px;background:rgba(0,0,0,.08);margin:20px 0}
.proj-content-grid{display:grid;grid-template-columns:1fr 280px;gap:36px;margin-top:8px}
@media(max-width:680px){.proj-content-grid{grid-template-columns:1fr;gap:24px}}
.proj-desc{font-size:14px;color:var(--text);line-height:1.65}
.proj-desc p{margin-bottom:12px}
.proj-details{background:var(--off);border-radius:10px;padding:18px 20px;border:1px solid rgba(0,0,0,.04)}
.proj-details-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.10em;color:var(--muted);margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid rgba(0,0,0,.06)}
.proj-detail-row{display:flex;flex-direction:column;margin-bottom:12px;font-size:13px}
.proj-detail-row:last-child{margin-bottom:0}
.proj-detail-row .lbl{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:3px}
.proj-detail-row .val{color:var(--navy-deep);font-weight:600;line-height:1.4}
.proj-cta{margin-top:28px;padding-top:24px;border-top:1px solid rgba(0,0,0,.08);display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.proj-cta-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;border-radius:50px;background:var(--accent);color:var(--navy-deep);font-size:13px;font-weight:700;text-decoration:none;border:1px solid var(--accent);cursor:pointer;font-family:'Manrope',sans-serif;transition:all .2s}
.proj-cta-btn:hover{background:#E0B560}
.proj-cta-note{font-size:12px;color:var(--muted)}


/* === v49 PROJECT POPUP — expanded sections + bigger size === */
.proj-modal{max-width:880px}
.proj-cover{aspect-ratio:21/9}
.proj-body{padding:36px 48px}
@media(max-width:560px){.proj-body{padding:24px 22px}}
.proj-sec{padding-top:28px;margin-top:28px;border-top:1px solid rgba(0,0,0,.08)}
.proj-sec:first-of-type{padding-top:24px;margin-top:24px}
.proj-sec-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.10em;color:var(--accent);margin-bottom:14px;display:flex;align-items:center;gap:10px}
.proj-sec-title::after{content:'';flex:1;max-width:60px;height:1px;background:var(--accent);opacity:.4}
.proj-prose{font-size:14px;color:var(--text);line-height:1.65}
.proj-prose p{margin-bottom:12px}
.proj-prose p:last-child{margin-bottom:0}
.proj-spec-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
@media(max-width:560px){.proj-spec-grid{grid-template-columns:1fr}}
.proj-spec{background:var(--off);border-radius:10px;padding:14px 18px;border:1px solid rgba(0,0,0,.04)}
.proj-spec-lbl{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.10em;color:var(--muted);margin-bottom:5px}
.proj-spec-val{font-size:14px;color:var(--navy-deep);font-weight:600;line-height:1.4}
.proj-credits-list{display:grid;grid-template-columns:160px 1fr;gap:6px 24px;font-size:13.5px}
@media(max-width:560px){.proj-credits-list{grid-template-columns:1fr;gap:0}}
.proj-credit-row{display:contents}
.proj-credit-row dt{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);align-self:start;padding-top:3px}
.proj-credit-row dd{margin:0;color:var(--navy-deep);font-weight:500;padding-bottom:8px}
@media(max-width:560px){.proj-credit-row dt{margin-top:8px}.proj-credit-row dd{padding-bottom:0}}
.proj-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
@media(max-width:680px){.proj-gallery{grid-template-columns:repeat(2,1fr)}}
.proj-gallery-item{position:relative;border-radius:8px;overflow:hidden;background:var(--off);aspect-ratio:4/3;margin:0}
.proj-gallery-item img{width:100%;height:100%;object-fit:cover;display:block}
.proj-gallery-item figcaption{position:absolute;bottom:0;left:0;right:0;padding:8px 12px;background:linear-gradient(0deg,rgba(13,31,60,.85),transparent);color:#fff;font-size:11px;font-weight:500}


/* === v50 TECH TAB REDESIGN === */
#st-main-tech .tech-eyebrow{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);display:flex;align-items:center;gap:10px;margin-bottom:14px}
#st-main-tech .tech-eyebrow::after{content:'';flex:0 0 60px;height:1px;background:var(--accent);opacity:.4}
#st-main-tech .tech-title{font-size:34px;font-weight:800;letter-spacing:-.02em;color:var(--navy-deep);line-height:1.1;margin-bottom:10px}
#st-main-tech .tech-sub{font-size:15px;color:var(--muted);max-width:680px;line-height:1.55;margin-bottom:8px}
#st-main-tech .tech-sub b{color:var(--navy-deep);font-weight:700}
#st-main-tech .philo{margin:24px 0 28px;padding:16px 22px;background:var(--accent-soft);border-left:3px solid var(--accent);border-radius:0 10px 10px 0;font-size:13px;color:var(--navy-deep);font-style:italic;line-height:1.5}
#st-main-tech .philo strong{font-style:normal;font-weight:700;color:var(--navy-deep)}
#st-main-tech .ladder{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin:28px 0 0;background:var(--off);border-radius:10px;padding:4px;position:relative}
#st-main-tech .ladder.cols-2{grid-template-columns:repeat(2,1fr)}
#st-main-tech .ladder.cols-3{grid-template-columns:repeat(3,1fr)}
#st-main-tech .ladder-step{padding:12px 14px;text-align:center;border-radius:8px;position:relative}
#st-main-tech .ladder-step .lvl{font-size:9.5px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:4px}
#st-main-tech .ladder-step .name{font-size:13.5px;font-weight:800;color:var(--navy-deep);letter-spacing:-.01em}
#st-main-tech .ladder-step.peak{background:var(--accent-soft);box-shadow:0 0 0 2px var(--accent) inset}
#st-main-tech .ladder-step.peak .lvl{color:var(--accent)}
#st-main-tech .ladder-arrow{display:flex;justify-content:space-around;font-size:13px;color:var(--muted);padding:6px 0}
#st-main-tech .ladder-arrow span{flex:1;text-align:center;font-size:9.5px;font-weight:600;color:rgba(13,31,60,.35);text-transform:uppercase;letter-spacing:.10em}
/* Comparison table */
#st-main-tech .cmp-wrap{margin-top:28px;border-radius:14px;overflow:hidden;border:1px solid rgba(13,31,60,.08);background:var(--white);box-shadow:0 2px 12px rgba(13,31,60,.04)}
#st-main-tech .cmp{width:100%;border-collapse:collapse;font-size:13px}
#st-main-tech .cmp thead th{background:var(--navy-deep);color:#fff;text-align:left;padding:16px 16px 14px;vertical-align:bottom;font-weight:600;position:relative}
#st-main-tech .cmp thead th:first-child{color:rgba(255,255,255,.55);font-size:10px;text-transform:uppercase;letter-spacing:.10em;font-weight:700;width:170px}
#st-main-tech .cmp thead .col-name{font-size:16px;font-weight:800;color:#fff;letter-spacing:-.01em;display:block}
#st-main-tech .cmp thead .col-tag{display:block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.50);margin-top:4px;margin-bottom:2px}
#st-main-tech .cmp thead .peak-ribbon{display:inline-block;background:var(--accent);color:var(--navy-deep);font-size:9.5px;font-weight:800;letter-spacing:.10em;text-transform:uppercase;padding:4px 9px;border-radius:4px;margin-top:8px;white-space:nowrap}
#st-main-tech .cmp thead th.peak{background:linear-gradient(180deg,#0D1F3C,#162a4a)}
#st-main-tech .cmp thead th.peak::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent)}
#st-main-tech .cmp tbody td{padding:13px 16px;border-top:1px solid rgba(13,31,60,.06);vertical-align:top;color:var(--text);transition:background .15s;font-size:13px}
#st-main-tech .cmp tbody tr:hover td{background:rgba(13,31,60,.02)}
#st-main-tech .cmp tbody td:first-child{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);background:var(--off);width:170px}
#st-main-tech .cmp tbody td.peak-col{background:rgba(212,161,74,.04)}
#st-main-tech .cmp tbody tr:hover td.peak-col{background:rgba(212,161,74,.08)}
#st-main-tech .bar{display:inline-flex;gap:3px;margin-top:2px}
#st-main-tech .bar i{width:18px;height:5px;background:var(--off2);border-radius:2px;display:block}
#st-main-tech .bar i.on{background:var(--navy-deep)}
#st-main-tech .bar.amber i.on{background:var(--accent)}
#st-main-tech .cell-y{color:var(--navy-deep);font-weight:600}
#st-main-tech .cell-n{color:rgba(13,31,60,.30);font-weight:500}
#st-main-tech .cell-meta{font-size:11px;color:var(--muted);font-weight:500;margin-top:3px;line-height:1.4}
#st-main-tech .warn{display:inline-flex;align-items:center;gap:5px;font-size:11px;color:var(--muted);font-weight:600;margin-top:3px}
#st-main-tech .warn::before{content:'!';display:inline-flex;width:14px;height:14px;border-radius:50%;background:var(--accent-soft);color:var(--accent);font-size:10px;font-weight:800;align-items:center;justify-content:center;flex-shrink:0}
#st-main-tech .cell-strong{font-weight:700;color:var(--navy-deep);font-size:13.5px}
/* Sub-options grid */
#st-main-tech .subs-wrap{margin-top:36px}
#st-main-tech .subs-title{font-size:11px;font-weight:700;letter-spacing:.10em;text-transform:uppercase;color:var(--accent);margin-bottom:14px;display:flex;align-items:center;gap:10px}
#st-main-tech .subs-title::after{content:'';flex:0 0 60px;height:1px;background:var(--accent);opacity:.4}
#st-main-tech .subs-row{display:grid;gap:12px;margin-bottom:12px;align-items:stretch}
#st-main-tech .subs-row.col2{grid-template-columns:140px 1fr 1fr}
#st-main-tech .subs-row.col3{grid-template-columns:140px 1fr 1fr 1fr}
#st-main-tech .subs-row.col1{grid-template-columns:140px 1fr}
#st-main-tech .subs-row.standalone-3{grid-template-columns:1fr 1fr 1fr}
#st-main-tech .subs-row.standalone-2{grid-template-columns:1fr 1fr}
@media(max-width:780px){
  #st-main-tech .subs-row,#st-main-tech .subs-row.col2,#st-main-tech .subs-row.col3,#st-main-tech .subs-row.col1,#st-main-tech .subs-row.standalone-3,#st-main-tech .subs-row.standalone-2{grid-template-columns:1fr}
}
#st-main-tech .subs-row-label{padding:16px 14px;background:var(--navy-deep);color:#fff;border-radius:10px;display:flex;flex-direction:column;justify-content:center}
#st-main-tech .subs-row-label .nm{font-size:16px;font-weight:800;letter-spacing:-.01em}
#st-main-tech .subs-row-label .sub{font-size:10px;color:rgba(255,255,255,.55);font-weight:600;margin-top:3px;text-transform:uppercase;letter-spacing:.06em}
#st-main-tech .sub-card{position:relative;background:var(--white);border:1px solid rgba(13,31,60,.08);border-radius:10px;padding:14px 16px;cursor:default;transition:all .15s}
#st-main-tech .sub-card.peak{border-color:var(--accent);background:rgba(212,161,74,.03)}
#st-main-tech .sub-card:hover{border-color:var(--accent);box-shadow:0 4px 16px rgba(212,161,74,.10)}
#st-main-tech .sub-card-name{font-size:14.5px;font-weight:800;color:var(--navy-deep);margin-bottom:4px}
#st-main-tech .sub-card-tag{font-size:10px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}
#st-main-tech .sub-card-desc{font-size:12px;color:var(--muted);line-height:1.5}
#st-main-tech .sub-card[data-tip]:hover::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);background:var(--navy-deep);color:#fff;padding:10px 14px;border-radius:8px;font-size:12px;font-weight:400;width:260px;line-height:1.5;z-index:100;box-shadow:0 8px 24px rgba(0,0,0,.25);font-style:normal;text-transform:none;letter-spacing:0;white-space:normal;font-family:'Manrope',sans-serif;pointer-events:none}
#st-main-tech .sub-card[data-tip]:hover::before{content:'';position:absolute;bottom:calc(100% + 2px);left:50%;transform:translateX(-50%);border:6px solid transparent;border-top-color:var(--navy-deep);z-index:100}
/* Section divider title between two tables in same tab */
#st-main-tech .tech-section-title{font-size:11px;font-weight:700;letter-spacing:.10em;text-transform:uppercase;color:var(--accent);margin:36px 0 8px;display:flex;align-items:center;gap:10px}
#st-main-tech .tech-section-title::after{content:'';flex:0 0 60px;height:1px;background:var(--accent);opacity:.4}
#st-main-tech .tech-section-sub{font-size:13px;color:var(--muted);margin-bottom:14px;line-height:1.5}
/* Base callout */
#st-main-tech .base-callout{background:var(--off);border:1px solid rgba(13,31,60,.08);border-radius:12px;padding:18px 22px;margin-top:28px;display:flex;align-items:center;gap:18px;flex-wrap:wrap}
#st-main-tech .base-callout-mark{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:var(--accent);color:var(--navy-deep);font-size:18px;font-weight:800;flex-shrink:0}
#st-main-tech .base-callout-body{flex:1;min-width:240px}
#st-main-tech .base-callout-name{font-size:15px;font-weight:800;color:var(--navy-deep);margin-bottom:3px}
#st-main-tech .base-callout-desc{font-size:12.5px;color:var(--muted);line-height:1.5}
/* Standalone sub-card grid (no left label) */
#st-main-tech .standalone-grid{display:grid;gap:12px;margin-top:14px}
/* Tech CTA */
#st-main-tech .tech-cta{margin-top:42px;padding-top:24px;border-top:1px solid rgba(13,31,60,.08);display:flex;gap:14px;align-items:center;flex-wrap:wrap;justify-content:space-between}
#st-main-tech .tech-cta .lhs{font-size:14px;color:var(--muted);max-width:480px;line-height:1.5}
#st-main-tech .tech-cta .lhs strong{color:var(--navy-deep);font-weight:700}
#st-main-tech .tech-cta-btn{display:inline-flex;align-items:center;gap:8px;padding:11px 22px;border-radius:50px;background:var(--navy-deep);color:#fff;font-size:13px;font-weight:700;text-decoration:none;border:1px solid var(--navy-deep);transition:all .2s;font-family:'Manrope',sans-serif;cursor:pointer}
#st-main-tech .tech-cta-btn:hover{background:#162a4a;transform:translateY(-1px);box-shadow:0 6px 18px rgba(13,31,60,.20)}

  .mc{background:#0D1F3C;border-radius:16px;padding:32px 24px 24px;font-family:'Manrope',system-ui,sans-serif;color:#C8D6E5;overflow:hidden;position:relative}
  .mc h2{font-size:22px;font-weight:500;color:#fff;margin:0 0 4px;letter-spacing:-.3px}
  .mc .sub{font-size:13px;color:#8BA4C0;margin:0 0 16px;line-height:1.5}
  .legend{display:flex;gap:16px;margin:0 0 12px;flex-wrap:wrap}
  .legend-item{display:flex;align-items:center;gap:6px;font-size:12px;color:#8BA4C0;cursor:pointer;user-select:none;transition:opacity .2s}
  .legend-item.dim{opacity:.3}
  .legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
  .map-wrap{position:relative;overflow:hidden;border-radius:8px;border:1px solid #1B408044}
  #map-svg{width:100%;display:block;cursor:grab}
  #map-svg:active{cursor:grabbing}
  .land{fill:#162D52;stroke:#1B4080;stroke-width:.3}
  .graticule{fill:none;stroke:#1B4080;stroke-width:.2;opacity:.3}
  .outline{fill:none;stroke:#1B4080;stroke-width:.5}
  .marker{cursor:pointer;transition:opacity .3s}
  .marker.dim{display:none}
  @keyframes pulse{0%{r:0;opacity:.6}100%{r:18;opacity:0}}
  .pulse-ring{animation:pulse 2s ease-out infinite;pointer-events:none}
  @keyframes pendingPulse{0%,100%{opacity:.4}50%{opacity:.9}}
  .pending-ring{animation:pendingPulse 1.5s ease-in-out infinite}
  .tooltip{position:absolute;background:rgba(13,31,60,.97);border:1px solid #1B4080;border-radius:8px;padding:10px 14px;font-size:12px;color:#C8D6E5;pointer-events:none;opacity:0;transition:opacity .15s;z-index:10;max-width:280px;backdrop-filter:blur(8px);white-space:normal;word-break:break-word}
  .tooltip .tt-title{font-size:13px;font-weight:500;color:#fff;margin:0 0 3px}
  .tooltip .tt-count{font-size:11px;color:#D4A14A;margin:0 0 5px}
  .tooltip .tt-client{font-size:11px;color:#8BA4C0;line-height:1.6}
  .tooltip .tt-cat{display:inline-block;font-size:9px;padding:1px 6px;border-radius:3px;margin-left:4px;vertical-align:middle}
  .zoom-ctrl{position:absolute;top:12px;right:12px;display:flex;flex-direction:column;gap:4px;z-index:5}
  .zoom-btn{width:32px;height:32px;background:rgba(13,31,60,.85);border:1px solid #1B4080;border-radius:6px;color:#C8D6E5;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;backdrop-filter:blur(6px);line-height:1}
  .zoom-btn:hover{background:rgba(27,64,128,.6)}
  .zoom-hint{position:absolute;bottom:8px;left:12px;font-size:10px;color:#8BA4C055;z-index:5}
  .preset-btns{display:flex;gap:6px;margin:0 0 12px;flex-wrap:wrap}
  .preset-btn{background:#162D52;border:1px solid #1B408066;border-radius:6px;padding:5px 12px;font-size:11px;color:#8BA4C0;cursor:pointer;transition:all .15s;font-family:inherit}
  .preset-btn:hover,.preset-btn.active{background:#1B4080;color:#fff;border-color:#1B4080}
  .stats-bar{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px;justify-content:center}
  .stat-chip{background:#162D52;border-radius:8px;padding:8px 14px;display:flex;align-items:center;gap:8px;font-size:12px;min-width:100px}
  .stat-chip .sn{font-size:18px;font-weight:500;color:#D4A14A}
  .stat-chip .sl{color:#8BA4C0;line-height:1.3}
  .stat-chip.pending{border:1px dashed #1B4080}
  .stat-chip.pending .sn{color:#1B4080}

/* ===== Footer enrichi 4 colonnes (override footer{display:flex} v50) ===== */
.site-footer{display:block;background:var(--navy-deep);color:rgba(255,255,255,.7);padding:0;text-align:left}
.footer-inner{max-width:1200px;margin:0 auto;padding:64px 48px 40px;display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:48px}
.footer-logo{font-size:22px;font-weight:700;color:var(--white);letter-spacing:-1px;margin-bottom:14px}
.footer-tagline{font-size:14px;color:rgba(255,255,255,.6);line-height:1.6;max-width:280px;margin-bottom:16px}
.footer-stats{font-size:12.5px;color:var(--accent);letter-spacing:.02em}
.footer-head{font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--white);margin-bottom:18px}
.footer-address{font-style:normal;font-size:13.5px;line-height:2;color:rgba(255,255,255,.65)}
.footer-address a{color:rgba(255,255,255,.65);text-decoration:none;transition:color .15s}
.footer-address a:hover{color:var(--accent)}
.footer-links{list-style:none;padding:0;margin:0}
.footer-links li{margin-bottom:11px}
.footer-links a{font-size:13.5px;color:rgba(255,255,255,.65);text-decoration:none;transition:color .15s}
.footer-links a:hover{color:var(--accent)}
.footer-social{display:flex;gap:14px}
.footer-social a{color:rgba(255,255,255,.6);transition:color .2s,transform .2s;line-height:0}
.footer-social a:hover{color:var(--accent);transform:translateY(-2px)}
.footer-bottom{max-width:1200px;margin:0 auto;padding:22px 48px;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;align-items:center;font-size:12.5px;color:rgba(255,255,255,.45)}
.footer-bottom a{color:rgba(255,255,255,.45);text-decoration:none;transition:color .15s}
.footer-bottom a:hover{color:var(--accent)}
@media(max-width:900px){.footer-inner{grid-template-columns:1fr 1fr;gap:36px;padding:48px 24px 32px}.footer-bottom{flex-direction:column;gap:10px;text-align:center;padding:22px 24px}}
@media(max-width:560px){.footer-inner{grid-template-columns:1fr}}

/* ===== Page detail use-case (modale -> page autonome) ===== */
.uc-detail{max-width:900px;margin:90px auto 0;padding:0 0 64px}
@media(max-width:900px){.uc-detail{margin-top:70px;padding:0 16px 48px}}

.proj-prose ul.proj-list{margin:.4em 0 1em 1.2em;padding:0}
.proj-prose li{margin:.3em 0;line-height:1.55}

/* Technology pages (migration) */
.tech-standalone{max-width:1100px;margin:0 auto;padding:40px 24px}
.tech-section-h{font-size:24px;font-weight:800;color:var(--navy);margin:0 0 22px}
.tech-hub-cards{max-width:1100px;margin:28px auto 8px;padding:0 24px;display:grid;grid-template-columns:1fr 1fr;gap:20px}
.tech-hub-card{display:block;text-decoration:none;background:var(--white);border:2px solid rgba(0,0,0,.06);border-radius:16px;padding:28px;transition:all .25s}
.tech-hub-card:hover{border-color:rgba(10,36,99,.2);box-shadow:0 10px 30px rgba(0,0,0,.07);transform:translateY(-3px)}
.tech-hub-card h3{font-size:20px;font-weight:800;color:var(--navy);margin:0 0 8px}
.tech-hub-card p{font-size:14px;color:var(--muted);line-height:1.6;margin:0 0 14px}
.tech-hub-link{font-size:13px;font-weight:700;color:var(--accent)}
@media(max-width:760px){.tech-hub-cards{grid-template-columns:1fr}}
