/* ===== VARIABLES ===== */
:root{
  --orange:#F26A1B;
  --ink:#0d0d0f;
  --paper:#f3f2ef;
  --paper-2:#ecebe7;
  --white:#ffffff;
  --text:#14141a;
  --muted:#6d6d78;
  --line:#e4e3df;
  --radius:26px;
  --radius-lg:34px;
  --shadow:0 30px 70px -30px rgba(20,20,26,.35);
  --shadow-sm:0 14px 34px -18px rgba(20,20,26,.3);
  --ease:cubic-bezier(.22,1,.36,1);
  --maxw:1240px;
}

/* ===== RESET ===== */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,sans-serif;
  background:var(--paper);
  color:var(--text);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  line-height:1.6;
  max-width:100vw;
}
h1,h2,h3,h4,h5{font-family:'Poppins',sans-serif;line-height:1.08;letter-spacing:-.02em}
img{display:block;max-width:100%;height:auto}
a{text-decoration:none;color:inherit}
button{font-family:inherit}

/* ===== UTILS ===== */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(16px,4vw,40px)}

.eyebrow{
  font-family:'Poppins';font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;font-size:12px;color:var(--orange);
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:24px;height:2px;background:var(--orange);border-radius:2px;flex-shrink:0}

/* ===== BUTTONS ===== */
.btn{
  display:inline-flex;align-items:center;gap:12px;
  font-family:'Poppins';font-weight:600;font-size:13px;
  letter-spacing:.06em;text-transform:uppercase;
  padding:7px 7px 7px 22px;border-radius:60px;border:none;
  cursor:pointer;white-space:nowrap;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease),background .3s;
}
.btn i{
  width:38px;height:38px;border-radius:50%;display:grid;place-items:center;
  font-style:normal;flex-shrink:0;
  transition:transform .5s var(--ease);
}
.btn:hover{transform:translateY(-3px)}
.btn:hover i{transform:rotate(45deg)}
.btn-orange{background:var(--orange);color:#fff;box-shadow:0 14px 28px -12px rgba(242,106,27,.65)}
.btn-orange i{background:var(--ink);color:#fff}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark i{background:var(--orange);color:#fff}

/* ===== REVEAL ANIMATIONS ===== */
.reveal{opacity:0;transform:translateY(36px);transition:opacity .85s var(--ease),transform .85s var(--ease)}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}

/* ===== NAVBAR ===== */
.topbar{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:clamp(10px,2vw,20px) clamp(16px,3vw,40px);
  transition:padding .4s var(--ease);
}
.topbar.shrink{padding:10px clamp(16px,3vw,40px)}
.nav{
  max-width:var(--maxw);margin:0 auto;
  display:flex;align-items:center;gap:12px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.22);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-radius:70px;
  padding:10px 10px 10px 22px;
  box-shadow:0 20px 50px -30px rgba(0,0,0,.6);
  transition:background .4s,box-shadow .4s;
}
.topbar.shrink .nav{background:rgba(13,13,15,.88);border-color:rgba(255,255,255,.1)}
.brand{
  display:flex;align-items:center;gap:9px;
  font-family:'Poppins';font-weight:800;font-size:clamp(18px,2.5vw,22px);
  color:#fff;letter-spacing:-.01em;flex-shrink:0;
}
.brand svg{width:28px;height:28px;flex-shrink:0}
.menu{display:flex;align-items:center;gap:2px;margin-left:10px}
.menu a{
  color:rgba(255,255,255,.9);font-family:'Poppins';font-weight:500;
  font-size:14px;padding:8px 13px;border-radius:40px;
  transition:.25s;display:flex;align-items:center;gap:4px;
}
.menu a .chev{width:7px;height:7px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg);margin-top:-2px;opacity:.65}
.menu a:hover{background:rgba(255,255,255,.14)}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.icon-btn{
  width:42px;height:42px;border-radius:50%;display:grid;place-items:center;
  background:rgba(255,255,255,.12);color:#fff;
  border:1px solid rgba(255,255,255,.18);cursor:pointer;transition:.25s;flex-shrink:0;
}
.icon-btn:hover{background:#fff;color:var(--ink)}
.grid-btn{background:var(--white)!important;color:var(--ink)!important}
.grid-btn svg{width:17px;height:17px}
.burger{
  display:none;flex-direction:column;gap:5px;
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);
  cursor:pointer;align-items:center;justify-content:center;flex-shrink:0;
}
.burger span{width:18px;height:2px;background:#fff;border-radius:2px;transition:.3s;display:block}
.burger.on span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.on span:nth-child(2){opacity:0}
.burger.on span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ===== MOBILE MENU ===== */
.mobile-menu{
  position:fixed;inset:0;background:rgba(13,13,15,.97);z-index:200;
  display:none;flex-direction:column;align-items:center;justify-content:center;
  gap:6px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
.mobile-menu.on{display:flex}
.mobile-menu a{
  color:#fff;font-family:'Poppins';font-weight:600;
  font-size:clamp(22px,6vw,32px);padding:14px 24px;border-radius:14px;
  transition:.2s;width:100%;max-width:320px;text-align:center;
}
.mobile-menu a:hover{background:rgba(255,255,255,.08);color:var(--orange)}
.mobile-menu .close-btn{
  position:absolute;top:24px;right:24px;
  width:46px;height:46px;border-radius:50%;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);
  color:#fff;font-size:22px;cursor:pointer;
  display:grid;place-items:center;transition:.2s;
}
.mobile-menu .close-btn:hover{background:var(--orange)}
.mobile-menu .cta-mobile{margin-top:20px}

/* ===== HERO ===== */
.hero{
  position:relative;min-height:100svh;min-height:100vh;
  display:flex;align-items:center;color:#fff;overflow:hidden;
  padding:clamp(120px,16vw,180px) 0 clamp(80px,10vw,110px);
}
.hero-bg{
  position:absolute;inset:0;
  background:url('https://images.unsplash.com/photo-1541888946425-d81bb19240f5?auto=format&fit=crop&q=80&w=1600') center/cover no-repeat;
  transform:scale(1.08);animation:heroZoom 14s var(--ease) forwards;
}
@keyframes heroZoom{to{transform:scale(1)}}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(105deg,rgba(9,9,11,.92) 0%,rgba(12,12,14,.6) 45%,rgba(12,12,14,.18) 75%);
}
.hero .wrap{position:relative;z-index:2;width:100%}
.hero-social{
  position:absolute;left:clamp(16px,2.5vw,34px);top:50%;
  transform:translateY(-50%);z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:20px;
}
.hero-social a{color:rgba(255,255,255,.72);font-size:14px;transition:.25s;line-height:1}
.hero-social a:hover{color:var(--orange);transform:translateY(-2px)}
.hero-social .vline{width:1px;height:56px;background:linear-gradient(rgba(255,255,255,.45),transparent);margin-top:4px}
.hero-social .vline::after{content:"";display:block;width:6px;height:6px;border-radius:50%;background:#fff;margin:52px auto 0}
.hero h1{
  font-size:clamp(36px,7.5vw,96px);font-weight:800;
  max-width:14ch;text-shadow:0 6px 36px rgba(0,0,0,.4);
}
.hero-cta-row{
  display:flex;align-items:flex-start;gap:clamp(20px,4vw,40px);
  margin-top:clamp(24px,4vw,40px);flex-wrap:wrap;
}
.hero p.sub{
  max-width:34ch;color:rgba(255,255,255,.85);
  font-size:clamp(14px,1.6vw,16px);line-height:1.65;
  align-self:center;
}
.reviews{
  display:flex;align-items:center;gap:14px;
  margin-top:clamp(28px,4vw,44px);flex-wrap:wrap;
}
.reviews .stars{color:#ffb020;letter-spacing:2px;font-size:15px}
.reviews .rlabel{font-family:'Poppins';font-weight:700;font-size:14px}
.avatars{display:flex}
.avatars img{
  width:clamp(40px,5vw,52px);height:clamp(40px,5vw,52px);
  border-radius:50%;border:3px solid rgba(255,255,255,.85);
  object-fit:cover;margin-left:-14px;
  box-shadow:0 4px 12px rgba(0,0,0,.4);
}
.avatars img:first-child{margin-left:0}
.ruler{
  position:absolute;left:0;right:0;bottom:-1px;height:clamp(50px,7vw,74px);z-index:3;
  background:var(--paper);border-top-left-radius:36px;border-top-right-radius:36px;
  display:flex;align-items:flex-start;overflow:hidden;
}
.ruler-ticks{display:flex;width:100%;height:36px;margin-top:8px}
.ruler-ticks .t{flex:1;border-left:1px solid #ccc;height:12px}
.ruler-ticks .t:nth-child(5n+1){height:24px}

/* ===== ABOUT ===== */
.about{padding:clamp(60px,8vw,100px) 0 clamp(50px,7vw,90px);background:var(--paper)}
.about-grid{
  display:grid;
  grid-template-columns:clamp(200px,22vw,280px) 1fr;
  gap:clamp(24px,4vw,48px);
  align-items:start;
}
.about-left{position:relative}
.about-left .tall{
  width:100%;
  aspect-ratio:3/4;
  object-fit:cover;
  border-radius:22px 22px 80px 22px;
}
.cone-wrap{
  position:absolute;left:50%;bottom:clamp(50px,8vw,80px);
  transform:translateX(-50%);width:clamp(110px,14vw,160px);
  filter:drop-shadow(0 18px 22px rgba(0,0,0,.22));pointer-events:none;
}
.cone-wrap svg{width:100%;height:auto}
.about-left .btn{margin-top:clamp(16px,2vw,26px)}
.about-head h2{
  font-size:clamp(26px,3.5vw,50px);font-weight:800;
  color:var(--ink);max-width:16ch;margin:12px 0 0;
}
.about-body{
  display:grid;
  grid-template-columns:1.05fr 1fr;
  gap:clamp(20px,3vw,36px);
  margin-top:clamp(20px,3vw,34px);
  align-items:start;
}
.about-body .photo{
  width:100%;
  aspect-ratio:3/4;
  object-fit:cover;
  border-radius:24px;
}
.vm h3{font-size:clamp(16px,1.8vw,20px);font-weight:700;color:var(--ink);margin-bottom:6px}
.vm p{color:var(--muted);font-size:clamp(13px,1.3vw,15px);margin-bottom:22px;line-height:1.7}
.stat-cards{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:4px}
.stat-card{
  border-radius:18px;padding:clamp(16px,2vw,22px) clamp(14px,1.8vw,20px);
  color:#fff;position:relative;overflow:hidden;
  display:flex;flex-direction:column;justify-content:space-between;
  min-height:clamp(110px,14vw,140px);
}
.stat-card.dark{background:var(--ink)}
.stat-card.or{background:var(--orange)}
.stat-card .lab{
  font-family:'Poppins';font-weight:700;font-size:10px;
  letter-spacing:.1em;text-transform:uppercase;opacity:.85;
}
.stat-card .num{
  font-family:'Poppins';font-weight:800;
  font-size:clamp(28px,3.5vw,40px);line-height:1;
}
.stat-card .num sup{font-size:clamp(14px,1.8vw,20px)}
.stat-card .sm{font-size:11.5px;opacity:.8}
.stat-card svg{position:absolute;right:12px;top:14px;width:30px;height:30px;opacity:.9;flex-shrink:0}

/* ===== SERVICES ===== */
.services{
  background:var(--ink);color:#fff;
  padding:clamp(70px,9vw,110px) 0;
  position:relative;overflow:hidden;
  border-radius:40px 40px 0 0;margin-top:-36px;
}
.services::after{
  content:"";position:absolute;right:-8%;top:20%;
  width:560px;height:560px;
  background:radial-gradient(circle,rgba(242,106,27,.5),transparent 62%);
  filter:blur(20px);pointer-events:none;
}
.services .wrap{position:relative;z-index:2}
.services-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(30px,5vw,70px);
  align-items:center;
}
.services h2{
  font-size:clamp(26px,3.5vw,46px);font-weight:800;
  margin:14px 0 clamp(20px,3vw,34px);max-width:13ch;
}
.svc-list{display:flex;flex-direction:column;gap:10px}
.svc{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  background:#202024;border-radius:60px;
  padding:clamp(12px,1.5vw,16px) clamp(12px,1.5vw,16px) clamp(12px,1.5vw,16px) clamp(18px,2vw,26px);
  cursor:pointer;transition:.4s var(--ease);
  border:1px solid rgba(255,255,255,.05);
}
.svc h3{font-size:clamp(14px,1.5vw,17px);font-weight:600;font-family:'Poppins'}
.svc .go{
  width:clamp(36px,4vw,44px);height:clamp(36px,4vw,44px);border-radius:50%;
  background:#2c2c31;display:grid;place-items:center;
  transition:.4s var(--ease);flex-shrink:0;
}
.svc.active{background:var(--orange)}
.svc.active .go{background:#fff;color:var(--ink)}
.svc:hover:not(.active){background:#26262b}
.svc-visual{position:relative}
.svc-card{position:relative;border-radius:24px;overflow:hidden;box-shadow:var(--shadow)}
.svc-card img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}
.svc-card .disc{position:absolute;right:16px;bottom:16px}
.svc-visual h3.title{
  font-size:clamp(20px,2.2vw,28px);font-weight:700;
  margin:clamp(16px,2vw,24px) 0 10px;
}
.svc-visual p.desc{
  color:rgba(255,255,255,.66);
  font-size:clamp(13px,1.3vw,15px);max-width:44ch;
}

/* ===== PROJECTS ===== */
.projects{
  padding:clamp(70px,9vw,100px) 0 clamp(40px,5vw,60px);
  background:var(--paper);text-align:center;
}
.projects h2{
  font-size:clamp(28px,4vw,52px);font-weight:800;
  color:var(--ink);max-width:18ch;margin:12px auto 0;
}
.proj-list{
  margin-top:clamp(36px,5vw,60px);
  display:flex;flex-direction:column;
  gap:clamp(20px,3vw,36px);text-align:left;
}
.proj{
  position:relative;border-radius:var(--radius-lg);
  overflow:hidden;min-height:clamp(280px,36vw,430px);
  display:flex;align-items:center;box-shadow:var(--shadow);
}
.proj img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;transition:transform 1.1s var(--ease);
}
.proj:hover img{transform:scale(1.06)}
.proj-card{
  position:relative;z-index:2;background:#fff;border-radius:22px;
  padding:clamp(20px,3vw,34px);
  width:clamp(260px,36vw,390px);
  margin:0 clamp(16px,4vw,48px);
  box-shadow:0 28px 56px -28px rgba(0,0,0,.35);
}
.proj.right{justify-content:flex-end}
.proj-card .top{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:12px;flex-wrap:wrap;gap:8px;
}
.proj-card .tag{color:var(--orange);font-family:'Poppins';font-weight:600;font-size:13px}
.proj-card .loc{display:flex;align-items:center;gap:5px;color:var(--muted);font-size:12.5px}
.proj-card h3{font-size:clamp(20px,2.4vw,28px);font-weight:800;color:var(--ink);line-height:1.1}
.proj-card p{color:var(--muted);font-size:13px;margin-top:10px;line-height:1.7}
.proj-card .fab{
  position:absolute;right:20px;bottom:-24px;
  width:50px;height:50px;border-radius:50%;
  background:var(--orange);color:#fff;display:grid;place-items:center;
  box-shadow:0 12px 24px -8px rgba(242,106,27,.65);
  transition:.4s var(--ease);font-size:18px;
}
.proj:hover .fab{transform:rotate(45deg)}

/* ===== TESTIMONIAL ===== */
.testi{
  background:#fff;padding:clamp(56px,7vw,80px) 0 clamp(70px,9vw,100px);
  position:relative;overflow:hidden;
  border-radius:40px 40px 0 0;margin-top:-28px;
}
.testi::after{
  content:"";position:absolute;right:-140px;bottom:-140px;
  width:480px;height:480px;border:110px solid var(--paper-2);border-radius:50%;
}
.testi .wrap{position:relative;z-index:2}
.testi-top{
  display:flex;align-items:center;justify-content:space-between;
  gap:clamp(14px,2vw,24px);flex-wrap:wrap;
}
.testi-top .l{display:flex;align-items:center;gap:clamp(12px,2vw,22px);flex-wrap:wrap}
.testi-top .rev .stars{color:var(--orange);font-size:15px;letter-spacing:2px}
.testi-top .rev .rl{font-family:'Poppins';font-weight:600;font-size:13.5px}
.testi-top .trust{font-family:'Poppins';font-weight:600;font-size:14px;color:var(--ink);line-height:1.35}
.testi-top .trust span{color:var(--muted);font-weight:400}
.quote{
  font-family:'Poppins';font-weight:700;
  font-size:clamp(18px,2.8vw,34px);
  color:var(--ink);max-width:24ch;
  margin-top:clamp(24px,3.5vw,40px);line-height:1.3;
  transition:opacity .35s ease;
}
.dots{display:flex;gap:8px;margin-top:28px}
.dots i{width:8px;height:8px;border-radius:50%;background:#d7d6d1;list-style:none}
.dots i.on{background:var(--ink);transform:scale(1.25)}

/* ===== STATS ===== */
.stats{
  padding:clamp(50px,7vw,80px) 0 clamp(30px,4vw,40px);
  background:var(--paper);
}
.stats-line{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:clamp(14px,2vw,20px);
  position:relative;
}
.stat-box{padding:clamp(14px,2vw,20px) 0 clamp(36px,5vw,70px);position:relative}
.stat-box.up{padding-top:clamp(36px,5vw,60px);padding-bottom:clamp(14px,2vw,20px)}
.stat-box .num{
  font-family:'Poppins';font-weight:800;
  font-size:clamp(30px,4vw,52px);color:var(--ink);line-height:1;
}
.stat-box .num sup{color:var(--orange);font-size:clamp(16px,2vw,22px)}
.stat-box .lab{
  font-family:'Poppins';font-weight:600;
  font-size:clamp(13px,1.3vw,15px);color:var(--ink);margin-top:4px;
  line-height:1.4;
}
.stat-box .stem{
  position:absolute;left:5px;bottom:0;
  width:1px;height:clamp(30px,4vw,50px);background:#c9c8c3;
}
.stat-box.up .stem{bottom:auto;top:0}
.stat-box .stem::after{
  content:"";position:absolute;left:-5px;bottom:-5px;
  width:11px;height:11px;border-radius:50%;
  background:#fff;border:2px solid #b5b4ae;
}
.stat-box.up .stem::after{bottom:auto;top:-5px}

/* ===== FAQ ===== */
.faq-wrap{
  background:var(--paper-2);border-radius:30px;
  margin-top:clamp(24px,3.5vw,36px);
  padding:clamp(36px,5vw,66px) clamp(20px,4vw,48px);
  display:grid;
  grid-template-columns:1fr 1.1fr;
  gap:clamp(24px,4vw,56px);
  align-items:center;
}
.faq-img{width:100%;max-width:480px;object-fit:contain;margin:0 auto;display:block}
.faq h2{
  font-size:clamp(26px,3.3vw,46px);font-weight:800;
  color:var(--ink);margin:12px 0 clamp(18px,2.5vw,28px);max-width:13ch;
}
.faq-list{display:flex;flex-direction:column;gap:12px}
.acc{background:#fff;border-radius:18px;overflow:hidden;box-shadow:var(--shadow-sm)}
.acc-head{
  display:flex;align-items:center;justify-content:space-between;
  gap:14px;padding:clamp(16px,2vw,20px) clamp(16px,2vw,20px) clamp(16px,2vw,20px) clamp(18px,2.2vw,24px);
  cursor:pointer;
}
.acc-head h4{
  font-size:clamp(13.5px,1.5vw,15.5px);font-weight:600;
  font-family:'Poppins';color:var(--ink);flex:1;line-height:1.4;
}
.acc-head .ic{
  width:clamp(34px,4vw,38px);height:clamp(34px,4vw,38px);border-radius:50%;
  background:var(--orange);color:#fff;display:grid;place-items:center;
  flex-shrink:0;transition:.4s var(--ease);font-size:16px;
}
.acc.open .acc-head .ic{background:var(--ink);transform:rotate(45deg)}
.acc-body{max-height:0;overflow:hidden;transition:max-height .55s var(--ease);will-change:max-height;}
.acc-body p{
  padding:0 clamp(16px,2.2vw,24px) clamp(16px,2vw,22px);
  color:var(--muted);font-size:clamp(13px,1.3vw,14.5px);line-height:1.75;
}

/* ===== CONTACT ===== */
.contact{padding:clamp(60px,8vw,100px) 0;background:var(--paper)}
.contact-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(30px,5vw,64px);align-items:start;
}
.contact h2{
  font-size:clamp(28px,3.8vw,52px);font-weight:800;
  color:var(--ink);margin:12px 0 clamp(20px,3vw,32px);
}
.info-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(18px,2.5vw,28px) clamp(14px,2vw,24px);
}
.info{display:flex;gap:12px;align-items:flex-start}
.info .ci{
  width:clamp(40px,4.5vw,48px);height:clamp(40px,4.5vw,48px);border-radius:50%;
  background:var(--orange);color:#fff;display:grid;place-items:center;
  flex-shrink:0;font-size:clamp(14px,1.8vw,18px);
}
.info h4{font-size:clamp(14px,1.5vw,16px);font-weight:700;font-family:'Poppins';color:var(--ink)}
.info p{font-size:clamp(12px,1.3vw,13.5px);color:var(--muted);margin-top:2px}
.contact-media{
  position:relative;margin-top:clamp(24px,3vw,36px);
  border-radius:24px;overflow:hidden;
}
.contact-media img{
  width:100%;aspect-ratio:16/9;object-fit:cover;display:block;
}
.play-btn{
  position:absolute;right:clamp(14px,2vw,24px);bottom:clamp(14px,2vw,24px);
  width:clamp(56px,7vw,74px);height:clamp(56px,7vw,74px);
  border-radius:50%;background:var(--ink);color:#fff;
  display:grid;place-items:center;cursor:pointer;
  box-shadow:0 0 0 0 rgba(242,106,27,.5);
  animation:pulse 2.4s infinite;border:none;font-size:clamp(18px,2.5vw,24px);
}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(242,106,27,.55)}70%{box-shadow:0 0 0 20px rgba(242,106,27,0)}100%{box-shadow:0 0 0 0 rgba(242,106,27,0)}}
.form-lead{color:var(--text);font-size:clamp(13.5px,1.5vw,15px);max-width:46ch;margin-bottom:clamp(18px,2.5vw,26px);line-height:1.7}
.form{display:grid;grid-template-columns:1fr 1fr;gap:clamp(10px,1.5vw,14px)}
.form .full{grid-column:1/-1}
.form input,.form select,.form textarea{
  width:100%;padding:clamp(13px,1.8vw,16px) clamp(14px,1.8vw,18px);
  border:1.5px solid var(--line);border-radius:12px;
  background:#fff;font-family:'Inter';
  font-size:clamp(13px,1.3vw,14px);color:var(--text);transition:.25s;
  -webkit-appearance:none;appearance:none;
}
.form textarea{min-height:clamp(100px,12vw,130px);resize:vertical}
.form input:focus,.form select:focus,.form textarea:focus{
  outline:none;border-color:var(--orange);
  box-shadow:0 0 0 3px rgba(242,106,27,.12);
}
.form-foot{
  display:flex;align-items:center;justify-content:space-between;
  gap:14px;margin-top:clamp(16px,2vw,22px);flex-wrap:wrap;
}
.form-foot p{font-size:clamp(12px,1.3vw,13px);color:var(--muted)}
.form-foot p b{color:var(--ink);font-family:'Poppins'}

/* ===== MARQUEE ===== */
.marquee-band{
  background:var(--orange);color:#fff;
  transform:rotate(-3deg);margin:clamp(28px,5vw,48px) 0;
  padding:clamp(13px,2vw,18px) 0;overflow:hidden;white-space:nowrap;
}
.marquee-band .track{
  display:inline-flex;gap:clamp(28px,4vw,50px);
  animation:scrollx 28s linear infinite;
  font-family:'Poppins';font-weight:700;
  font-size:clamp(15px,2.2vw,23px);letter-spacing:.02em;text-transform:uppercase;
}
.marquee-band .track b{color:#ffd9c2}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ===== BLOG ===== */
.blog{padding:clamp(20px,4vw,30px) 0 clamp(70px,9vw,100px);background:var(--paper)}
.blog-head{
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:20px;flex-wrap:wrap;margin-bottom:clamp(28px,4vw,46px);
}
.blog-head h2{
  font-size:clamp(26px,3.5vw,46px);font-weight:800;
  color:var(--ink);margin-top:12px;line-height:1.1;
}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2.5vw,28px)}
.post{}
.post .thumb{
  position:relative;border-radius:20px;overflow:hidden;
  aspect-ratio:16/10;
}
.post .thumb img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.post:hover .thumb img{transform:scale(1.06)}
.post .date{
  position:absolute;right:12px;bottom:12px;
  background:var(--ink);color:#fff;
  font-family:'Poppins';font-weight:600;
  font-size:clamp(10px,1.2vw,12px);
  padding:6px 13px;border-radius:30px;
}
.post .meta{
  display:flex;gap:14px;color:var(--muted);
  font-size:clamp(11px,1.2vw,12.5px);
  margin:clamp(12px,1.8vw,16px) 0 clamp(8px,1vw,10px);
  flex-wrap:wrap;
}
.post .meta span{display:flex;align-items:center;gap:5px}
.post .meta i{color:var(--orange);font-style:normal}
.post h3{
  font-size:clamp(16px,1.8vw,20px);font-weight:700;
  font-family:'Poppins';color:var(--ink);line-height:1.28;max-width:22ch;
}
.post .more{
  display:inline-flex;align-items:center;gap:7px;
  margin-top:clamp(12px,1.8vw,16px);
  font-family:'Poppins';font-weight:600;
  font-size:clamp(11px,1.2vw,12.5px);
  letter-spacing:.06em;text-transform:uppercase;
  color:var(--ink);background:#fff;
  padding:clamp(9px,1.3vw,12px) clamp(14px,2vw,20px);
  border-radius:30px;box-shadow:var(--shadow-sm);transition:.3s;
}
.post .more.hl{background:var(--orange);color:#fff}
.post .more:hover{transform:translateX(4px)}

/* ===== FOOTER ===== */
.foot{
  background:var(--ink);color:#fff;
  border-radius:40px 40px 0 0;
  padding:0 0 0;position:relative;overflow:hidden;
  margin-top:clamp(14px,3vw,24px);
}
.newsletter{
  background:#1a1a1e;border-radius:30px;
  margin:clamp(-30px,-4vw,-44px) clamp(12px,2vw,24px) 0;
  padding:clamp(28px,4vw,46px) clamp(20px,3.5vw,48px);
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(18px,3vw,34px);align-items:center;
  position:relative;z-index:3;box-shadow:var(--shadow);
}
.newsletter h3{font-size:clamp(22px,2.8vw,40px);font-weight:800}
.newsletter p{color:rgba(255,255,255,.6);font-size:clamp(12.5px,1.4vw,14.5px);margin-top:6px}
.news-form{
  display:flex;background:#fff;border-radius:60px;
  padding:7px 7px 7px clamp(14px,2vw,22px);align-items:center;gap:6px;
}
.news-form input{
  flex:1;border:none;background:transparent;outline:none;
  font-family:'Inter';font-size:clamp(12.5px,1.4vw,14px);color:var(--text);
  min-width:0;
}
.foot-main{padding:clamp(36px,5vw,56px) 0 0;position:relative;z-index:2}
.foot-ghost{
  position:absolute;left:0;right:0;bottom:clamp(20px,4vw,44px);
  text-align:center;font-family:'Poppins';font-weight:900;
  font-size:clamp(60px,16vw,240px);
  color:rgba(255,255,255,.03);letter-spacing:.02em;
  pointer-events:none;z-index:1;line-height:1;
}
.foot-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:clamp(18px,3vw,36px);
  position:relative;z-index:2;
}
.foot .brand{color:#fff;margin-bottom:clamp(12px,1.5vw,18px)}
.foot-about p{
  color:rgba(255,255,255,.55);
  font-size:clamp(12.5px,1.3vw,13.5px);max-width:34ch;line-height:1.75;
}
.foot-social{display:flex;align-items:center;gap:10px;margin-top:clamp(16px,2vw,22px)}
.foot-social span{font-family:'Poppins';font-weight:600;font-size:clamp(13px,1.4vw,14.5px)}
.foot-social a{
  width:33px;height:33px;border-radius:50%;
  background:rgba(255,255,255,.1);display:grid;place-items:center;
  transition:.25s;font-size:12.5px;
}
.foot-social a:hover{background:var(--orange)}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:clamp(10px,1.5vw,14px)}
.foot-col li{
  color:rgba(255,255,255,.62);font-size:clamp(12.5px,1.3vw,14px);
  display:flex;align-items:center;gap:8px;cursor:pointer;transition:.2s;
}
.foot-col li::before{content:"•";color:rgba(255,255,255,.35);flex-shrink:0}
.foot-col li:hover{color:#fff}
.foot-col li.act{color:var(--orange)}
.foot-bar{
  margin:clamp(28px,4vw,46px) 0 clamp(16px,2vw,22px);
  background:rgba(255,255,255,.05);border-radius:40px;
  padding:clamp(13px,1.8vw,17px) clamp(18px,2.8vw,30px);
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;flex-wrap:wrap;position:relative;z-index:2;
}
.foot-bar p,.foot-bar a{font-size:clamp(11.5px,1.3vw,13px);color:rgba(255,255,255,.6)}
.foot-bar .r{display:flex;gap:clamp(16px,2.5vw,26px)}

/* =============================================
   RESPONSIVE — 4 breakpoints cleans
   ============================================= */

/* ---- LAPTOP ≤ 1080px ---- */
@media(max-width:1080px){
  .menu,.nav .btn:not(.icon-btn){display:none}
  .burger{display:flex}
  .about-grid{grid-template-columns:1fr}
  .about-left .tall{aspect-ratio:4/3;max-height:340px}
  .cone-wrap{bottom:clamp(30px,5vw,60px);width:clamp(80px,12vw,130px)}
  .about-body{grid-template-columns:1fr 1fr}
  .services-grid{grid-template-columns:1fr;gap:36px}
  .svc-visual{order:-1}
  .svc-card img{aspect-ratio:16/9}
  .faq-wrap{grid-template-columns:1fr}
  .faq-img{max-width:360px}
  .contact-grid{grid-template-columns:1fr}
  .newsletter{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr;gap:clamp(18px,3vw,32px) clamp(14px,3vw,24px)}
  .stats-line{grid-template-columns:1fr 1fr;gap:clamp(16px,3vw,24px)}
  .stat-box .stem{display:none}
  .hero-social{display:none}
}

/* ---- TABLET ≤ 768px ---- */
@media(max-width:768px){
  .about-body{grid-template-columns:1fr}
  .about-body .photo{aspect-ratio:16/9}
  .stat-cards{grid-template-columns:1fr 1fr}
  .blog-grid{grid-template-columns:1fr 1fr}
  .proj-card{
    width:auto;max-width:none;
    margin:clamp(14px,2vw,20px) clamp(14px,2vw,20px) clamp(30px,4vw,40px);
    border-radius:18px;
  }
  .proj{min-height:clamp(240px,45vw,360px)}
  .proj.right{justify-content:flex-start}
  .info-grid{grid-template-columns:1fr 1fr}
  .testi-top{flex-direction:column;align-items:flex-start}
  .marquee-band{transform:rotate(-2.5deg)}
  .newsletter{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .stat-cards{gap:12px}
}

/* ---- MOBILE ≤ 480px ---- */
@media(max-width:480px){
  .nav{padding:8px 8px 8px 16px;border-radius:50px}
  .brand{font-size:17px}
  .brand svg{width:22px;height:22px}
  .icon-btn.search-btn{display:none}
  .hero h1{font-size:clamp(32px,9vw,48px)}
  .hero-cta-row{flex-direction:column;gap:16px}
  .reviews{flex-direction:column;align-items:flex-start;gap:10px}
  .btn{font-size:12px;padding:7px 7px 7px 18px}
  .btn i{width:34px;height:34px}
  .about-grid{grid-template-columns:1fr}
  .about-left .tall{aspect-ratio:3/2;max-height:260px;border-radius:18px 18px 60px 18px}
  .cone-wrap{display:none}
  .stat-cards{grid-template-columns:1fr 1fr}
  .svc{padding:12px 12px 12px 16px}
  .svc h3{font-size:13.5px}
  .proj-card h3{font-size:20px}
  .blog-grid{grid-template-columns:1fr}
  .form{grid-template-columns:1fr}
  .form .full{grid-column:1}
  .info-grid{grid-template-columns:1fr}
  .form-foot{flex-direction:column;align-items:flex-start}
  .form-foot .btn{width:100%;justify-content:center}
  .foot-grid{grid-template-columns:1fr}
  .foot-bar{flex-direction:column;align-items:flex-start;gap:10px}
  .foot-bar .r{flex-direction:column;gap:8px}
  .stats-line{grid-template-columns:1fr 1fr}
  .testi-top .l{flex-wrap:wrap;gap:10px}
  .newsletter{padding:24px 18px}
  .news-form{flex-direction:column;border-radius:18px;padding:10px}
  .news-form input{padding:10px 12px;width:100%}
  .news-form .btn{width:100%;justify-content:center}
  .faq-wrap{padding:28px 16px}
  .blog-head{flex-direction:column;align-items:flex-start}
  .marquee-band{transform:rotate(-2deg)}
  .ruler{height:44px}
}

/* ---- TRÈS PETIT ≤ 360px ---- */
@media(max-width:360px){
  .wrap{padding:0 14px}
  .hero h1{font-size:30px}
  .stat-cards{grid-template-columns:1fr}
  .blog-grid,.stats-line{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .info-grid{grid-template-columns:1fr}
}

/* ===== TOUCH / HOVER ===== */
@media(hover:none){
  .btn:hover{transform:none}
  .btn:active{transform:scale(.97)}
  .svc:hover:not(.active){background:#202024}
  .post .more:hover{transform:none}
  .post .more:active{transform:translateX(4px)}
}

/* ===== MOTION RÉDUIT ===== */
@media(prefers-reduced-motion:reduce){
  .hero-bg,.reveal,.btn,.svc,.acc-head .ic,.proj img,
  .post .thumb img,.marquee-band .track{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}

/* ===== PRINT ===== */
@media print{
  .topbar,.hero-social,.mobile-menu,.burger,.marquee-band,.play-btn{display:none!important}
  .hero{min-height:auto;padding:40px 0}
  .foot-ghost{display:none}
}

/* ============================================
   ADDITIONS MULTI-PAGES (n'altèrent pas le design existant)
   ============================================ */

/* Breadcrumb */
.breadcrumb{background:var(--paper);padding:calc(clamp(90px,12vw,120px) + 20px) 0 10px}
.breadcrumb .wrap{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.breadcrumb a,.breadcrumb span{font-family:'Inter',sans-serif;font-size:13.5px;color:var(--muted)}
.breadcrumb a{transition:color .2s}
.breadcrumb a:hover{color:var(--orange)}
.breadcrumb .sep{opacity:.5}
.breadcrumb .current{color:var(--ink);font-weight:600}

/* Page transitions */
.page-view{animation:pageIn .5s var(--ease)}
@keyframes pageIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}

/* Page hero (réutilise les tokens existants) */
.page-hero{position:relative;padding:calc(clamp(90px,12vw,120px) + 40px) 0 clamp(50px,7vw,80px);background:var(--ink);color:#fff;overflow:hidden}
.page-hero::after{content:"";position:absolute;right:-6%;top:10%;width:480px;height:480px;background:radial-gradient(circle,rgba(242,106,27,.4),transparent 62%);filter:blur(20px);pointer-events:none}
.page-hero .wrap{position:relative;z-index:2}
.page-hero .eyebrow{color:var(--orange)}
.page-hero h1{font-size:clamp(32px,5vw,64px);font-weight:800;margin-top:14px;max-width:18ch}
.page-hero p{color:rgba(255,255,255,.75);font-size:clamp(14px,1.6vw,17px);max-width:52ch;margin-top:16px}

/* Content sections génériques */
.section{padding:clamp(50px,7vw,90px) 0;background:var(--paper)}
.section.white{background:#fff}
.section-head{text-align:center;max-width:640px;margin:0 auto clamp(36px,5vw,56px)}
.section-head h2{font-size:clamp(26px,3.6vw,46px);font-weight:800;color:var(--ink);margin-top:14px}
.section-head p{color:var(--muted);margin-top:12px;font-size:15px}

/* Prose (articles blog / légal) */
.prose{max-width:760px;margin:0 auto;color:var(--text)}
.prose h2{font-size:clamp(22px,2.6vw,32px);font-weight:800;color:var(--ink);margin:36px 0 14px}
.prose h3{font-size:clamp(18px,2vw,24px);font-weight:700;color:var(--ink);margin:28px 0 10px}
.prose p{font-size:16px;line-height:1.8;color:#3a3a44;margin-bottom:18px}
.prose ul,.prose ol{margin:0 0 18px 22px}
.prose li{font-size:16px;line-height:1.8;color:#3a3a44;margin-bottom:8px}
.prose img{border-radius:20px;margin:24px 0}
.prose blockquote{border-left:4px solid var(--orange);padding:8px 0 8px 22px;margin:24px 0;font-style:italic;color:var(--ink);font-size:18px}
.prose a{color:var(--orange);text-decoration:underline}

/* Grille cartes génériques */
.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2.5vw,28px)}
.card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .5s var(--ease),box-shadow .5s var(--ease);display:flex;flex-direction:column}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card .card-img{aspect-ratio:16/10;overflow:hidden}
.card .card-img img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.card:hover .card-img img{transform:scale(1.06)}
.card .card-body{padding:24px;display:flex;flex-direction:column;gap:10px;flex:1}
.card .card-cat{font-family:'Poppins',sans-serif;font-weight:600;font-size:12px;color:var(--orange);text-transform:uppercase;letter-spacing:.08em}
.card h3{font-size:19px;font-weight:700;font-family:'Poppins',sans-serif;color:var(--ink);line-height:1.3}
.card p{font-size:14px;color:var(--muted);line-height:1.6;flex:1}
.card .card-link{font-family:'Poppins',sans-serif;font-weight:600;font-size:13px;color:var(--ink);display:inline-flex;align-items:center;gap:8px;margin-top:6px;transition:gap .3s}
.card:hover .card-link{gap:14px;color:var(--orange)}

/* Feature list (avantages / processus) */
.feature-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(18px,3vw,32px)}
.feature{display:flex;gap:16px;align-items:flex-start;background:#fff;padding:26px;border-radius:20px;box-shadow:var(--shadow-sm)}
.feature .fnum{width:48px;height:48px;border-radius:50%;background:var(--orange);color:#fff;display:grid;place-items:center;font-family:'Poppins',sans-serif;font-weight:800;flex-shrink:0}
.feature h4{font-size:18px;font-weight:700;font-family:'Poppins',sans-serif;color:var(--ink);margin-bottom:6px}
.feature p{font-size:14px;color:var(--muted);line-height:1.6}

/* Gallery */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.gallery img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:16px;cursor:pointer;transition:transform .5s var(--ease),filter .3s}
.gallery img:hover{transform:scale(1.02);filter:brightness(1.05)}

/* CTA band */
.cta-band{background:var(--ink);border-radius:var(--radius-lg);padding:clamp(40px,6vw,70px);text-align:center;color:#fff;position:relative;overflow:hidden}
.cta-band::after{content:"";position:absolute;left:50%;top:-40%;transform:translateX(-50%);width:600px;height:600px;background:radial-gradient(circle,rgba(242,106,27,.35),transparent 60%);pointer-events:none}
.cta-band .wrap-inner{position:relative;z-index:2}
.cta-band h2{font-size:clamp(26px,3.4vw,44px);font-weight:800;max-width:20ch;margin:0 auto 14px}
.cta-band p{color:rgba(255,255,255,.7);max-width:48ch;margin:0 auto 28px;font-size:15px}

/* Two-col layout */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,60px);align-items:center}
.two-col img{width:100%;border-radius:var(--radius);object-fit:cover}
.two-col h2{font-size:clamp(24px,3vw,40px);font-weight:800;color:var(--ink);margin-bottom:18px}
.two-col p{color:var(--muted);font-size:15px;line-height:1.75;margin-bottom:14px}

/* Meta project info */
.proj-meta{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin:34px 0}
.proj-meta .pm{background:#fff;padding:22px;border-radius:18px;box-shadow:var(--shadow-sm)}
.proj-meta .pm .k{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-weight:600}
.proj-meta .pm .v{font-family:'Poppins',sans-serif;font-weight:700;font-size:18px;color:var(--ink);margin-top:6px}

/* Post navigation */
.post-nav{display:flex;justify-content:space-between;gap:20px;margin-top:40px;flex-wrap:wrap}
.post-nav a{display:flex;flex-direction:column;gap:4px;padding:18px 26px;background:#fff;border-radius:16px;box-shadow:var(--shadow-sm);transition:.3s;max-width:48%}
.post-nav a:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.post-nav a .dir{font-size:12px;color:var(--orange);font-weight:600;text-transform:uppercase;letter-spacing:.06em}
.post-nav a .ttl{font-family:'Poppins',sans-serif;font-weight:700;color:var(--ink);font-size:15px}
.post-nav a.next{text-align:right;margin-left:auto}

/* Back to top */
.back-top{position:fixed;right:24px;bottom:24px;width:52px;height:52px;border-radius:50%;background:var(--orange);color:#fff;display:grid;place-items:center;cursor:pointer;box-shadow:0 14px 28px -12px rgba(242,106,27,.65);opacity:0;visibility:hidden;transform:translateY(20px);transition:.4s var(--ease);z-index:90;border:none;font-size:20px}
.back-top.show{opacity:1;visibility:visible;transform:none}
.back-top:hover{transform:translateY(-4px)}

/* 404 */
.notfound{min-height:80vh;display:grid;place-items:center;text-align:center;background:var(--paper);padding:120px 20px 80px}
.notfound h1{font-size:clamp(90px,20vw,220px);font-weight:900;color:var(--ink);line-height:1;font-family:'Poppins',sans-serif}
.notfound h1 span{color:var(--orange)}
.notfound p{font-size:18px;color:var(--muted);margin:10px 0 30px}

/* Menu actif */
.menu a.active,.mobile-menu a.active{color:var(--orange)}

/* Responsive additions */
@media(max-width:1080px){
  .cards-grid{grid-template-columns:1fr 1fr}
  .proj-meta{grid-template-columns:1fr 1fr}
  .two-col{grid-template-columns:1fr}
  .feature-grid{grid-template-columns:1fr}
}
@media(max-width:640px){
  .cards-grid,.gallery{grid-template-columns:1fr}
  .proj-meta{grid-template-columns:1fr 1fr}
  .post-nav a{max-width:100%}
  .gallery{grid-template-columns:1fr 1fr}
}

/* 4K / grands écrans */
@media(min-width:2200px){
  :root{--maxw:1600px}
  body{font-size:18px}
}

/* ============================================
   ANTI-ZONES-VIDES — Fallbacks de sécurité
   ============================================ */

/* Fallback : si JS ne charge pas, le contenu devient visible après 2s */
@keyframes revealFallback { to { opacity:1; transform:none; } }
.reveal { animation: revealFallback 0s linear 1s forwards; }
/* Quand .in est ajouté par JS, l'animation normale prend le dessus immédiatement */
.reveal.in { animation: none; opacity:1; transform:none; }

/* Empêcher tout élément noscript de casser la mise en page */
noscript { display:block; }

/* Sécurité : aucune section ne doit être totalement transparente au repos prolongé */
.page-view .reveal { will-change: opacity, transform; }

/* Grille équipe / 4 colonnes → responsive */
@media(max-width:1080px){
  .cards-grid[style*="repeat(4"]{grid-template-columns:repeat(2,1fr)!important}
}
@media(max-width:560px){
  .cards-grid[style*="repeat(4"]{grid-template-columns:1fr!important}
}
