/* ===== Compressed Air Technology — compresseur.ma ===== */
:root{
  --navy:#0F2A52;
  --navy-deep:#0A1F3D;
  --navy-mid:#1B3A6B;
  --orange:#F47B20;
  --orange-deep:#E0660D;
  --blue:#3D8BD4;
  --ink:#14213D;
  --grey:#5A6B82;
  --line:#E2E8F2;
  --bg:#FFFFFF;
  --bg-soft:#F4F7FB;
  --bg-card:#F8FAFD;
  --white:#FFFFFF;
  --shadow:0 10px 40px -12px rgba(15,42,82,.18);
  --shadow-lg:0 24px 60px -18px rgba(15,42,82,.30);
  --radius:16px;
  --maxw:1200px;
  --font-display:"Archivo",-apple-system,sans-serif;
  --font-body:"Inter",-apple-system,sans-serif;
}

@import url('https://fonts.googleapis.com/css2?family=Archivo:wght@500;600;700;800;900&family=Inter:wght@400;500;600;700&display=swap');

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--bg);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4{font-family:var(--font-display);line-height:1.12;color:var(--navy);letter-spacing:-.02em}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.accent-bar{width:54px;height:5px;background:var(--orange);border-radius:3px;margin-bottom:22px}
section{position:relative}

/* ===== Header ===== */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px;overflow:visible}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--font-display);font-weight:800;color:var(--navy);font-size:1.05rem;line-height:1.05;max-height:74px;overflow:hidden}
.brand .logo{width:42px;height:42px;flex:none}
.brand img.logo-img{height:46px;max-height:46px;width:auto;max-width:190px;flex:none;object-fit:contain;display:block}
.brand .logo-mark{width:42px;height:42px;flex:none}
.brand .brand-text{display:flex;flex-direction:column;font-family:var(--font-display);font-weight:800;font-size:1.08rem;letter-spacing:.01em;color:var(--navy);line-height:1}
.brand .brand-text small{font-weight:700;font-size:.6rem;letter-spacing:.34em;color:var(--orange);margin-top:3px}
.brand.brand-on-dark .brand-text{color:#fff}
.brand.brand-on-dark .brand-text small{color:var(--orange)}
.brand small{display:block;font-size:.62rem;letter-spacing:.18em;color:var(--orange);font-weight:700}
.nav-links{display:flex;gap:30px;align-items:center;list-style:none}
.nav-links a{font-weight:600;font-size:.93rem;color:var(--navy);transition:color .2s;position:relative}
.nav-links a:hover,.nav-links a.active{color:var(--orange)}
.nav-links a.active::after{content:"";position:absolute;left:0;bottom:-26px;height:3px;width:100%;background:var(--orange)}
.nav-cta{background:var(--orange);color:#fff!important;padding:11px 22px;border-radius:10px;font-weight:700;transition:.25s;box-shadow:0 8px 20px -8px rgba(244,123,32,.6)}
.nav-cta:hover{background:var(--orange-deep);transform:translateY(-1px)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.burger span{width:26px;height:3px;background:var(--navy);border-radius:2px;transition:.3s}

/* ===== Hero ===== */
.hero{
  background:
    radial-gradient(1200px 500px at 80% -10%, rgba(61,139,212,.18), transparent 60%),
    linear-gradient(135deg,var(--navy-deep) 0%,var(--navy) 55%,var(--navy-mid) 100%);
  color:#fff;position:relative;overflow:hidden;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background-image:repeating-linear-gradient(115deg,rgba(255,255,255,.03) 0 2px,transparent 2px 26px);
  pointer-events:none;
}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:50px;align-items:center;padding:88px 0 96px}
.hero h1{color:#fff;font-size:clamp(2.3rem,4.6vw,3.7rem);font-weight:900}
.hero .lead{color:#C7D6EC;font-size:1.18rem;margin:22px 0 10px;max-width:560px}
.hero .tagline{color:var(--orange);font-weight:700;font-style:italic;font-size:1.05rem;margin-bottom:30px}
.hero-badges{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}
.hbadge{display:flex;align-items:center;gap:9px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);padding:10px 16px;border-radius:30px;font-size:.85rem;font-weight:600;color:#E7EFFA}
.hbadge b{color:var(--orange)}
.btn-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:14px}
.btn{display:inline-flex;align-items:center;gap:9px;padding:14px 28px;border-radius:11px;font-weight:700;font-size:.97rem;transition:.25s;cursor:pointer;border:0}
.btn-primary{background:var(--orange);color:#fff;box-shadow:0 12px 28px -10px rgba(244,123,32,.7)}
.btn-primary:hover{background:var(--orange-deep);transform:translateY(-2px)}
.btn-ghost{background:rgba(255,255,255,.07);color:#fff;border:1.5px solid rgba(255,255,255,.3)}
.btn-ghost:hover{background:rgba(255,255,255,.14)}
.hero-visual{position:relative}
.hero-disc{
  aspect-ratio:1;border-radius:50%;
  background:linear-gradient(160deg,#2C4E82,#0E2342);
  border:2px solid rgba(255,255,255,.12);
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow-lg);position:relative;overflow:hidden;
}
.hero-disc::after{content:"";position:absolute;inset:14px;border:1.5px solid rgba(255,255,255,.10);border-radius:50%}
.hero-disc svg{width:55%;height:55%;opacity:.95}
.hero-disc img.hero-photo{width:100%;height:100%;object-fit:cover}
.float-247{position:absolute;right:8px;bottom:18px;background:var(--orange);color:#fff;padding:14px 22px;border-radius:14px;font-family:var(--font-display);font-weight:800;font-size:1.1rem;box-shadow:var(--shadow-lg)}

/* ===== Stats strip ===== */
.stats{background:var(--navy-deep);color:#fff}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding:38px 0;text-align:center}
.stat .num{font-family:var(--font-display);font-weight:900;font-size:2.4rem;color:var(--orange);line-height:1}
.stat .lbl{font-size:.82rem;color:#A9BDD8;margin-top:6px;letter-spacing:.02em}

/* ===== Section heads ===== */
.sec{padding:88px 0}
.sec.soft{background:var(--bg-soft)}
.sec-head{max-width:720px;margin-bottom:48px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head.center .accent-bar{margin-left:auto;margin-right:auto}
.sec-head h2{font-size:clamp(1.8rem,3.2vw,2.6rem);font-weight:800}
.sec-head p{color:var(--grey);font-size:1.1rem;margin-top:14px}
.eyebrow{color:var(--orange);font-weight:700;letter-spacing:.14em;text-transform:uppercase;font-size:.78rem;margin-bottom:10px}

/* ===== Service cards ===== */
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.svc-card{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  padding:30px 26px;transition:.3s;position:relative;overflow:hidden;
}
.svc-card::before{content:"";position:absolute;left:0;right:0;bottom:0;height:4px;background:var(--orange);transform:scaleX(0);transform-origin:left;transition:.3s}
.svc-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.svc-card:hover::before{transform:scaleX(1)}
.svc-ico{width:56px;height:56px;border-radius:13px;background:var(--navy);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.svc-ico svg{width:30px;height:30px;stroke:#fff;fill:none;stroke-width:1.7}
.svc-card.feat .svc-ico{background:var(--orange)}
.svc-card h3{font-size:1.16rem;margin-bottom:8px}
.svc-card p{color:var(--grey);font-size:.92rem}

/* ===== References ===== */
.ref-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:26px}
.ref-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:34px 28px;text-align:center;box-shadow:var(--shadow);position:relative}
.ref-card::before{content:"";position:absolute;top:0;left:28px;right:28px;height:5px;background:var(--orange);border-radius:0 0 4px 4px}
.ref-card h3{font-size:1.6rem;font-weight:900;color:var(--navy)}
.ref-card .sector{font-size:.78rem;letter-spacing:.08em;color:var(--grey);text-transform:uppercase;margin-top:6px}
.ref-card hr{border:0;border-top:1px solid var(--line);margin:18px 0}
.ref-card .amount{font-family:var(--font-display);font-weight:900;font-size:1.7rem;color:var(--orange)}
.ref-card .amount small{display:block;font-size:.75rem;color:var(--grey);font-weight:500;font-family:var(--font-body);margin-top:4px}
.ref-band{background:var(--navy);color:#fff;border-radius:var(--radius);padding:28px 34px;display:flex;flex-wrap:wrap;gap:30px;align-items:center;justify-content:space-between}
.ref-band .lbl{font-size:.78rem;letter-spacing:.1em;color:#A9BDD8;text-transform:uppercase;margin-bottom:14px;width:100%}
.ref-band .item{flex:1;min-width:140px}
.ref-band .item b{font-family:var(--font-display);font-size:1.35rem;color:#fff;display:block}
.ref-band .item span{font-size:.8rem;color:#A9BDD8}
.sectors{display:flex;gap:10px;flex-wrap:wrap}
.sector-pill{border:1.5px solid rgba(255,255,255,.35);border-radius:30px;padding:7px 16px;font-size:.82rem;font-weight:600}

/* ===== Why us ===== */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.why-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;transition:.3s}
.why-card:hover{box-shadow:var(--shadow);transform:translateY(-4px)}
.why-card .top{display:flex;align-items:center;gap:14px;margin-bottom:14px}
.why-card .wico{width:48px;height:48px;border-radius:11px;background:var(--bg-soft);display:flex;align-items:center;justify-content:center;flex:none}
.why-card .wico svg{width:26px;height:26px;stroke:var(--orange);fill:none;stroke-width:1.8}
.why-card h3{font-size:1.08rem}
.why-card p{color:var(--grey);font-size:.92rem}

/* ===== Locations ===== */
.loc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.loc-card{background:var(--white);border:1px solid var(--line);border-left:5px solid var(--orange);border-radius:12px;padding:26px 24px;box-shadow:var(--shadow);transition:.3s}
.loc-card:hover{transform:translateY(-4px)}
.loc-card .city{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:800;font-size:1.25rem;color:var(--navy)}
.loc-card .city svg{width:20px;height:24px;fill:var(--orange)}
.loc-card .addr{color:var(--grey);font-size:.92rem;margin-top:8px;padding-left:30px}

/* ===== CTA band ===== */
.cta-band{background:linear-gradient(135deg,var(--navy-deep),var(--navy-mid));color:#fff;text-align:center;padding:72px 0}
.cta-band h2{color:#fff;font-size:clamp(1.8rem,3.4vw,2.7rem)}
.cta-band p{color:#C7D6EC;font-size:1.12rem;margin:16px auto 30px;max-width:600px}

/* ===== Footer ===== */
.footer{background:var(--navy-deep);color:#9DB3D2;padding:60px 0 28px;font-size:.92rem}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;margin-bottom:40px}
.footer h4{color:#fff;font-size:1rem;margin-bottom:18px}
.footer ul{list-style:none}
.footer li{margin-bottom:10px}
.footer a:hover{color:var(--orange)}
.footer .brand{color:#fff;margin-bottom:16px}
.footer .brand small{color:var(--orange)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.84rem}

/* ===== Page hero (inner pages) ===== */
.page-hero{background:linear-gradient(135deg,var(--navy-deep),var(--navy));color:#fff;padding:70px 0 64px;position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(115deg,rgba(255,255,255,.03) 0 2px,transparent 2px 26px)}
.page-hero h1{color:#fff;font-size:clamp(2rem,4vw,3rem);font-weight:900;position:relative}
.page-hero p{color:#C7D6EC;font-size:1.15rem;margin-top:14px;max-width:640px;position:relative}
.breadcrumb{font-size:.85rem;color:#8FA6C6;margin-bottom:18px;position:relative}
.breadcrumb a:hover{color:var(--orange)}

/* ===== Detailed service blocks ===== */
.svc-detail{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}
.detail-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:32px 28px;transition:.3s}
.detail-card:hover{box-shadow:var(--shadow)}
.detail-card .dico{width:54px;height:54px;border-radius:13px;background:var(--orange);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.detail-card .dico svg{width:28px;height:28px;stroke:#fff;fill:none;stroke-width:1.8}
.detail-card h3{font-size:1.2rem;margin-bottom:10px}
.detail-card p{color:var(--grey);font-size:.94rem;margin-bottom:14px}
.detail-card ul{list-style:none}
.detail-card li{padding-left:24px;position:relative;color:var(--ink);font-size:.92rem;margin-bottom:8px}
.detail-card li::before{content:"";position:absolute;left:0;top:9px;width:8px;height:8px;border-radius:50%;background:var(--orange)}
.tag{display:inline-block;background:var(--orange);color:#fff;font-size:.74rem;font-weight:700;padding:4px 12px;border-radius:20px;margin:2px 4px 2px 0}

/* ===== ISO table ===== */
.iso-table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.iso-table th{background:var(--navy);color:#fff;padding:16px 18px;text-align:left;font-family:var(--font-display);font-size:.95rem}
.iso-table td{padding:14px 18px;border-bottom:1px solid var(--line);font-size:.92rem}
.iso-table tr:nth-child(even){background:var(--bg-soft)}
.iso-badge{display:inline-flex;width:30px;height:30px;border-radius:50%;background:var(--orange);color:#fff;align-items:center;justify-content:center;font-weight:800;font-size:.9rem}

/* ===== Maintenance timeline ===== */
.maint-row{background:var(--bg-card);border-radius:var(--radius);padding:28px 30px;margin-bottom:18px;display:grid;grid-template-columns:auto 1fr;gap:22px;align-items:center;border:1px solid var(--line)}
.maint-row .mico{width:58px;height:58px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex:none}
.maint-row .mico svg{width:30px;height:30px;stroke:#fff;fill:none;stroke-width:1.8}
.maint-row.prev .mico{background:var(--navy)}
.maint-row.corr .mico{background:var(--orange)}
.maint-row.cond .mico{background:var(--blue)}
.maint-row h3{font-size:1.2rem;margin-bottom:4px}
.maint-row p{color:var(--grey);font-size:.93rem}
.visit-chips{display:flex;gap:18px;flex-wrap:wrap;margin-top:10px}
.visit-chip{font-family:var(--font-display);font-weight:700;color:var(--navy);font-size:.9rem;display:flex;flex-direction:column}
.visit-chip small{color:var(--orange);font-weight:600}

/* ===== Contact ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.contact-info .ci-item{display:flex;gap:16px;margin-bottom:26px}
.contact-info .ci-ico{width:50px;height:50px;border-radius:12px;background:var(--navy);display:flex;align-items:center;justify-content:center;flex:none}
.contact-info .ci-ico svg{width:24px;height:24px;stroke:#fff;fill:none;stroke-width:1.8}
.contact-info h4{color:var(--navy);font-size:1.02rem;margin-bottom:3px}
.contact-info p,.contact-info a{color:var(--grey);font-size:.95rem}
.contact-info a:hover{color:var(--orange)}
.form-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:36px;box-shadow:var(--shadow)}
.form-row{margin-bottom:18px}
.form-row label{display:block;font-weight:600;font-size:.88rem;color:var(--navy);margin-bottom:7px}
.form-row input,.form-row select,.form-row textarea{
  width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:10px;font-family:var(--font-body);font-size:.95rem;transition:.2s;background:#fff;
}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{outline:0;border-color:var(--orange);box-shadow:0 0 0 3px rgba(244,123,32,.12)}
.form-row textarea{resize:vertical;min-height:120px}
.form-two{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-note{font-size:.82rem;color:var(--grey);margin-top:10px}

/* ===== Blog ===== */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.blog-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:.3s;display:flex;flex-direction:column}
.blog-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.blog-thumb{height:180px;background:linear-gradient(135deg,var(--navy),var(--navy-mid));display:flex;align-items:center;justify-content:center;position:relative}
.blog-thumb svg{width:64px;height:64px;stroke:rgba(255,255,255,.5);fill:none;stroke-width:1.4}
.blog-thumb .cat{position:absolute;top:14px;left:14px;background:var(--orange);color:#fff;font-size:.72rem;font-weight:700;padding:4px 12px;border-radius:20px}
.blog-body{padding:24px;flex:1;display:flex;flex-direction:column}
.blog-body .date{font-size:.78rem;color:var(--orange);font-weight:600;margin-bottom:8px}
.blog-body h3{font-size:1.12rem;margin-bottom:10px}
.blog-body p{color:var(--grey);font-size:.9rem;flex:1}
.blog-body .more{color:var(--navy);font-weight:700;font-size:.88rem;margin-top:14px;display:inline-flex;gap:6px;align-items:center}
.blog-card:hover .more{color:var(--orange)}

/* ===== Reveal animation ===== */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ===== Responsive ===== */
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:36px}
  .hero-visual{max-width:380px;margin:0 auto}
  .svc-grid,.why-grid,.ref-grid,.loc-grid,.blog-grid{grid-template-columns:repeat(2,1fr)}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:30px}
  .contact-grid{grid-template-columns:1fr;gap:36px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:30px}
}
@media(max-width:640px){
  .nav-links{
    position:fixed;top:74px;left:0;right:0;background:#fff;flex-direction:column;
    padding:22px 24px;gap:18px;border-bottom:1px solid var(--line);
    transform:translateY(-130%);transition:.35s;box-shadow:var(--shadow);height:auto;
  }
  .nav-links.open{transform:translateY(0)}
  .nav-links a.active::after{display:none}
  .burger{display:flex}
  .svc-grid,.why-grid,.ref-grid,.loc-grid,.blog-grid,.form-two{grid-template-columns:1fr}
  .sec{padding:60px 0}
  .ref-band{flex-direction:column;align-items:flex-start}
}
