/* ============================================================
   VEGA CONSULTING — style.css
   Palette : bleu nuit + blanc / crème (sans doré)
   ============================================================ */
:root{
  --navy-900:#0a1220;
  --navy-800:#0f1a2b;
  --navy-700:#16233a;
  --navy-600:#1a2740;
  --navy-500:#1e2c47;
  --line:rgba(255,255,255,.12);
  --line-soft:rgba(255,255,255,.07);
  --cream:#ece3d3;
  --cream-2:#e3d9c6;
  --white:#f2f4f8;
  --muted:#97a0b2;
  --muted-2:#6f788c;
  --serif:'Playfair Display',Georgia,serif;
  --serif-display:'Cormorant Garamond',Georgia,serif;
  --sans:'Montserrat',-apple-system,BlinkMacSystemFont,sans-serif;
  --script:'Great Vibes',cursive;
  --addr:'Allura','Great Vibes',cursive;
  --maxw:1180px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--navy-800);
  color:var(--white);
  font-family:var(--sans);
  font-weight:300;
  line-height:1.7;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
body.intro-lock{overflow:hidden;height:100vh}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
em{font-style:italic}

/* ---------- Typo helpers ---------- */
.eyebrow{
  font-size:11px;letter-spacing:.34em;text-transform:uppercase;
  color:var(--muted-2);font-weight:400;margin-bottom:1.4rem;
}
.title-lg{
  font-family:var(--serif-display);font-weight:500;
  font-size:clamp(1.85rem,3.9vw,3rem);line-height:1.18;
  letter-spacing:.012em;color:var(--white);
}
.title-lg .key{color:var(--cream)}
.title-lg.center{text-align:center}
.section-sub{
  color:var(--muted);max-width:620px;margin:1.4rem auto 0;
  text-align:center;font-size:.98rem;
}
.rule{display:block;width:60px;height:1px;background:var(--cream);opacity:.6;margin:1.8rem 0}
.center-rule{margin:1.6rem auto 0}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;font-family:var(--sans);font-size:12px;
  letter-spacing:.22em;text-transform:uppercase;font-weight:400;
  padding:18px 38px;cursor:pointer;transition:.4s ease;text-align:center;
}
.btn-outline{border:1px solid rgba(255,255,255,.35);color:var(--white);background:transparent}
.btn-outline:hover{border-color:var(--cream);background:rgba(236,227,211,.06);letter-spacing:.27em}
.btn-cream{background:var(--cream);color:#1a1f2b;border:1px solid var(--cream)}
.btn-cream:hover{background:transparent;color:var(--cream);letter-spacing:.27em}
.btn.full{display:block;width:100%}

/* ============================================================
   INTRO ANIMATION
   ============================================================ */
#intro{
  position:fixed;inset:0;z-index:9999;background:var(--navy-900);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;overflow:hidden;
}
#intro.done{animation:introOut 1.1s ease forwards}
@keyframes introOut{to{opacity:0;visibility:hidden}}
.intro-stage{position:relative;display:flex;align-items:center;justify-content:center}
.intro-logo{
  width:240px;height:auto;opacity:0;transform:scale(.84);transform-origin:50% 50%;
  animation:logoIn 1.4s .2s ease forwards, logoZoom 1.7s 2s cubic-bezier(.6,0,.85,1) forwards;
  filter:drop-shadow(0 0 30px rgba(150,180,255,.35));
}
@keyframes logoIn{to{opacity:1;transform:scale(1)}}
@keyframes logoZoom{0%{transform:scale(1);opacity:1}62%{opacity:0}100%{transform:scale(4.6);opacity:0}}
.intro-glow{
  position:absolute;width:64px;height:64px;border-radius:50%;
  background:radial-gradient(circle,rgba(232,242,255,.98) 0%,rgba(170,195,255,.3) 38%,rgba(150,180,255,0) 70%);
  opacity:0;pointer-events:none;
  animation:glow 1.7s 2s ease-out forwards;
}
@keyframes glow{0%{opacity:0;transform:scale(.3)}40%{opacity:.95}100%{opacity:0;transform:scale(12)}}
.intro-skip{
  position:absolute;bottom:42px;left:0;right:0;text-align:center;
  font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--muted-2);
  animation:skipPulse 2.4s infinite;
}
@keyframes skipPulse{0%,100%{opacity:.25}50%{opacity:.7}}

/* ============================================================
   CUSTOM CURSOR
   ============================================================ */
.cursor-star{
  position:fixed;top:0;left:0;width:16px;height:16px;pointer-events:none;
  z-index:10001;transform:translate(-50%,-50%);transition:width .18s,height .18s,opacity .25s;
  will-change:transform;
}
.cursor-star svg{width:100%;height:100%;fill:#eef3ff;filter:drop-shadow(0 0 5px rgba(150,180,255,.85))}
.cursor-star.hot{width:26px;height:26px}
body.intro-lock .cursor-star{opacity:0 !important}
body.has-cursor{cursor:none}
body.has-cursor a,body.has-cursor button,body.has-cursor input,body.has-cursor select,body.has-cursor textarea{cursor:none}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:900;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px clamp(20px,5vw,64px);
  transition:background .4s ease,padding .4s ease,border-color .4s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{background:rgba(7,11,20,.82);backdrop-filter:blur(12px);padding:14px clamp(20px,5vw,64px);border-bottom:1px solid var(--line-soft)}
.nav-logo img{width:58px;height:auto;filter:drop-shadow(0 0 12px rgba(120,160,255,.4))}
.nav-links{display:flex;align-items:center;gap:clamp(18px,3vw,42px)}
.nav-links a{font-size:12px;letter-spacing:.2em;color:rgba(242,244,248,.82);transition:.3s}
.nav-links a:hover{color:#fff}
.nav-cta{border:1px solid rgba(255,255,255,.3);padding:11px 24px}
.nav-cta:hover{border-color:var(--cream);background:rgba(236,227,211,.05)}
.nav-burger{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:6px}
.nav-burger span{width:26px;height:1.5px;background:#fff;transition:.3s}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;min-height:100vh;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;
  background:radial-gradient(ellipse at 50% 40%,#11203a 0%,var(--navy-900) 70%);
  overflow:hidden;padding:0 20px;
}
.hero-stars{
  position:absolute;inset:0;
  background:url('assets/img/stars.jpg') center/cover no-repeat;
  opacity:.55;
}
.hero-canvas{position:absolute;inset:0;width:100%;height:100%}
.hero::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(7,11,20,.5),rgba(7,11,20,.2) 45%,var(--navy-800));}
.hero-inner{position:relative;z-index:2;max-width:880px}
.hero-title{
  font-family:var(--serif-display);font-weight:500;
  font-size:clamp(2.6rem,7vw,5.2rem);line-height:1.08;letter-spacing:.015em;
  margin-bottom:1.6rem;text-shadow:0 2px 40px rgba(0,0,0,.5);
}
.hero-title em{font-style:italic}
.hero-sub{color:var(--muted);font-size:clamp(1rem,2.2vw,1.25rem);font-style:italic;margin-bottom:2.6rem;font-family:var(--serif)}
.hero .eyebrow{color:rgba(236,227,211,.7)}
.hero-scroll{
  position:absolute;bottom:34px;left:50%;transform:translateX(-50%);z-index:2;
  font-size:10px;letter-spacing:.4em;color:var(--muted-2);
}
.hero-scroll::after{content:'';display:block;width:1px;height:34px;margin:10px auto 0;background:linear-gradient(var(--muted-2),transparent);animation:scrollPulse 2s infinite}
@keyframes scrollPulse{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

/* ============================================================
   SECTION GENERICS
   ============================================================ */
.section{position:relative;padding:clamp(80px,11vw,150px) clamp(20px,5vw,64px);max-width:1320px;margin:0 auto}
.section-head{margin-bottom:clamp(48px,7vw,90px)}
.section-head .eyebrow{text-align:center}

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

/* ============================================================
   POURQUOI
   ============================================================ */
.pourquoi-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,84px);align-items:center}
.pourquoi-img img{width:100%;height:100%;object-fit:cover;box-shadow:0 30px 70px rgba(0,0,0,.5)}
.title-lg em{font-family:var(--serif-display);font-style:italic}
.bullets{list-style:none;margin-top:.4rem}
.bullets li{position:relative;padding-left:28px;margin-bottom:1.5rem;color:var(--muted);font-size:.98rem;max-width:40ch}
.bullets li::before{content:'✦';position:absolute;left:0;top:0;color:var(--cream);opacity:.7;font-size:.8rem}

/* ============================================================
   SERVICES
   ============================================================ */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;max-width:1180px;margin:0 auto}
.service-card{background:var(--navy-700);overflow:hidden;display:flex;flex-direction:column}
.service-img{overflow:hidden;aspect-ratio:4/3}
.service-img img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.service-card:hover .service-img img{transform:scale(1.06)}
.service-body{padding:32px 30px 40px}
.service-num{font-family:var(--serif);font-size:.9rem;color:var(--muted-2);letter-spacing:.1em}
.service-body h3{font-family:var(--serif);font-weight:400;font-size:1.5rem;line-height:1.2;margin:.5rem 0 1rem}
.service-body p{color:var(--muted);font-size:.9rem}

/* ============================================================
   À PROPOS
   ============================================================ */
.apropos-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(40px,7vw,96px);align-items:center}
.apropos-img{position:relative}
.apropos-img img{width:100%;position:relative;z-index:2;box-shadow:0 30px 70px rgba(0,0,0,.55)}
.apropos-frame{position:absolute;inset:26px -26px -26px 26px;border:1px solid var(--line);z-index:1}
.script-title{font-family:var(--script);font-size:clamp(2.4rem,5vw,3.4rem);color:var(--cream);line-height:1;margin-bottom:1.8rem}
.apropos-text>p:not(.script-title):not(.signature):not(.signature-role):not(.eyebrow){color:var(--muted);margin-bottom:1.3rem;max-width:46ch}
.signature{font-family:var(--serif);font-size:1.7rem;color:var(--white);margin-top:.4rem}
.signature-role{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--cream-2);opacity:.85;margin-top:.4rem}

/* ============================================================
   MÉTHODE
   ============================================================ */
.methode{text-align:center}
.timeline{position:relative;display:grid;grid-template-columns:repeat(5,1fr);gap:24px;max-width:1100px;margin:0 auto;padding-top:30px}
.timeline-line{position:absolute;top:54px;left:10%;right:10%;height:1px;background:var(--line)}
.step{position:relative;z-index:2}
.step-num{
  display:flex;align-items:center;justify-content:center;width:64px;height:64px;margin:0 auto 22px;
  border:1px solid var(--line);border-radius:50%;background:var(--navy-800);
  font-family:var(--serif);font-size:1.1rem;color:var(--cream-2);
}
.step h4{font-family:var(--serif);font-weight:400;font-size:1.2rem;margin-bottom:.6rem}
.step p{color:var(--muted);font-size:.82rem;max-width:18ch;margin:0 auto}

/* ============================================================
   TARIFS
   ============================================================ */
.tarifs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.4vw,34px);max-width:1180px;margin:0 auto}
.tarif-card{background:rgba(220,213,197,.06);color:var(--white);padding:46px 38px 40px;display:flex;flex-direction:column;border:1px solid rgba(236,227,211,.16);backdrop-filter:blur(6px)}
.tarif-cat{font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--muted-2);margin-bottom:1rem}
.tarif-card h3{font-family:var(--serif);font-weight:400;font-size:1.7rem;color:var(--white)}
.tarif-desc{font-style:italic;color:var(--muted);font-size:.88rem;margin:.5rem 0 2rem;font-family:var(--serif)}
.tarif-card ul{list-style:none;flex:1}
.tarif-card li{display:flex;justify-content:space-between;gap:14px;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.08);font-size:.92rem}
.tarif-card li span:first-child{color:var(--muted)}
.tarif-card li span:last-child{font-family:var(--serif);color:var(--cream);white-space:nowrap}
.tarif-foot{margin-top:1.8rem;font-style:italic;font-size:.78rem;color:var(--muted-2);text-align:center;font-family:var(--serif)}

/* ============================================================
   CTA BAND
   ============================================================ */
.cta-band{text-align:center}
.cta-inner{max-width:760px;margin:0 auto;padding:clamp(50px,7vw,80px) clamp(24px,5vw,70px);border:1px solid var(--line)}
.cta-inner .btn{margin-top:2.4rem}

/* ============================================================
   FAQ
   ============================================================ */
.faq-list{max-width:820px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{
  width:100%;background:none;border:none;color:var(--white);text-align:left;
  font-family:var(--sans);font-weight:400;font-size:1.05rem;
  padding:26px 0;display:flex;justify-content:space-between;align-items:center;gap:20px;cursor:pointer;
}
.faq-icon{position:relative;width:14px;height:14px;flex:none}
.faq-icon::before,.faq-icon::after{content:'';position:absolute;background:var(--cream);transition:.3s;top:50%;left:50%}
.faq-icon::before{width:14px;height:1px;transform:translate(-50%,-50%)}
.faq-icon::after{width:1px;height:14px;transform:translate(-50%,-50%)}
.faq-item.open .faq-icon::after{transform:translate(-50%,-50%) scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .45s ease}
.faq-a p{color:var(--muted);font-size:.95rem;padding:0 0 26px;max-width:70ch}

/* ============================================================
   PORTFOLIO
   ============================================================ */
.port-subtitle{text-align:center;font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted-2);margin-top:.8rem}
.portfolio .section-head{margin-bottom:clamp(28px,4vw,50px)}
.port-filters{display:flex;justify-content:center;flex-wrap:wrap;gap:8px;margin:0 auto clamp(30px,4vw,50px);max-width:780px}
.pf-btn{background:transparent;border:1px solid var(--line);color:var(--muted-2);font-family:var(--sans);font-size:10px;letter-spacing:.2em;text-transform:uppercase;padding:9px 18px;cursor:pointer;transition:.3s}
.pf-btn:hover,.pf-btn.active{border-color:var(--cream);color:var(--cream)}
.port-grid.schema{display:grid;grid-template-columns:1.5fr 1fr 1fr;grid-auto-rows:228px;gap:16px;max-width:1080px;margin:0 auto}
.port-item{display:flex;flex-direction:column;min-width:0}
.port-item.soutoura{grid-column:1;grid-row:1 / span 2}
.port-item.gentlemen{grid-column:2 / span 2;grid-row:1}
.port-item.comm{grid-column:2;grid-row:2}
.port-item.print{grid-column:3;grid-row:2}
.port-thumb{position:relative;flex:1;min-height:0;overflow:hidden;display:block;background:var(--navy-900)}
.port-thumb img{width:100%;height:100%;object-fit:cover;filter:brightness(.9) saturate(.98);transition:transform .7s ease,filter .5s ease}
.port-thumb:hover img{transform:scale(1.05);filter:brightness(1.03) saturate(1.05)}
.port-veil{position:absolute;inset:0;background:rgba(7,11,20,.10);transition:.4s;pointer-events:none}
.port-thumb:hover .port-veil{background:transparent}
.print-pair{display:flex;width:100%;height:100%;gap:4px}
.print-pair img{width:50%;height:100%;object-fit:cover}
.port-cap{padding:13px 2px 0;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:10px;flex:none}
.port-cap::before{content:'';width:22px;height:1px;background:var(--cream);opacity:.75;flex:none}
.port-thumb{cursor:zoom-in}
.print-pair img{cursor:zoom-in}
.port-zoom{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.9);font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:#fff;border:1px solid rgba(255,255,255,.7);padding:9px 20px;opacity:0;transition:.4s;pointer-events:none;background:rgba(7,11,20,.32);white-space:nowrap}
.port-thumb:hover .port-zoom{opacity:1;transform:translate(-50%,-50%) scale(1)}
.lightbox{position:fixed;inset:0;z-index:9999;background:rgba(5,8,14,.94);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:6vh 5vw;opacity:0;visibility:hidden;transition:opacity .35s,visibility .35s}
.lightbox.open{opacity:1;visibility:visible}
.lb-img{max-width:92vw;max-height:88vh;width:auto;height:auto;box-shadow:0 30px 80px rgba(0,0,0,.6);transform:scale(.96);transition:transform .35s}
.lightbox.open .lb-img{transform:scale(1)}
.lb-close{position:fixed;top:22px;right:30px;background:none;border:none;color:#fff;font-size:36px;line-height:1;cursor:pointer;opacity:.8;z-index:10000}
.lb-close:hover{opacity:1}
@media(max-width:760px){
  .port-grid.schema{grid-template-columns:1fr 1fr;grid-auto-rows:190px;gap:12px}
  .port-item.soutoura{grid-column:1 / -1;grid-row:auto}
  .port-item.gentlemen{grid-column:1 / -1;grid-row:auto}
  .port-item.comm{grid-column:1;grid-row:auto}
  .port-item.print{grid-column:2;grid-row:auto}
}
.brands{text-align:center;margin-top:clamp(50px,7vw,86px)}
.brands-label{font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--muted-2);margin-bottom:1.6rem}
.brands-row{display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(24px,5vw,64px)}
.brands-row span{font-family:var(--serif);font-size:1.2rem;color:rgba(242,244,248,.5);transition:.3s}
.brands-row span:hover{color:var(--cream)}

/* ============================================================
   CONTACT
   ============================================================ */
.contact{overflow:hidden}
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(40px,7vw,90px);position:relative;z-index:2}
.contact-list{list-style:none;margin:2rem 0}
.contact-list li{display:flex;align-items:center;gap:14px;padding:12px 0;color:var(--muted);font-size:.98rem}
.contact-list .ci{color:var(--cream);width:20px;text-align:center}
.contact-vega{font-family:var(--serif);font-size:clamp(3rem,7vw,5rem);letter-spacing:.3em;color:rgba(242,244,248,.16);margin-top:2rem}
.contact-form label{display:block;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted-2);margin-bottom:18px}
.contact-form input,.contact-form select,.contact-form textarea{
  width:100%;margin-top:9px;background:rgba(255,255,255,.03);border:1px solid var(--line);
  color:var(--white);font-family:var(--sans);font-weight:300;font-size:.95rem;padding:15px 16px;transition:.3s;
}
.contact-form textarea{resize:vertical}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:#5a6478}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{outline:none;border-color:var(--cream);background:rgba(255,255,255,.05)}
.contact-form select{appearance:none}
.contact-form .btn{margin-top:6px}
.contact-form .btn-outline{margin-top:14px}
.form-note{color:var(--cream);text-align:center;font-size:.9rem;margin-top:16px}
.end-band{position:relative;text-align:center;padding:clamp(120px,17vw,200px) 24px;overflow:hidden;background:radial-gradient(ellipse at 50% 50%,#11203a 0%,var(--navy-800) 72%)}
.end-stars{position:absolute;inset:0;background:url('assets/img/stars.jpg') center/cover no-repeat;opacity:.55}
.end-band::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,var(--navy-800) 0%,rgba(15,26,43,0) 32%,rgba(15,26,43,0) 68%,var(--navy-800) 100%)}
.end-inner{position:relative;z-index:2}
.end-logo{position:absolute;left:clamp(20px,5vw,64px);bottom:clamp(22px,4vw,44px);width:52px;height:auto;z-index:3;filter:drop-shadow(0 0 12px rgba(120,160,255,.4));opacity:.92}
.end-divider{display:block;width:1px;height:46px;background:linear-gradient(var(--cream),transparent);margin:0 auto 30px;opacity:.55}
.end-band p{font-family:var(--serif-display);font-style:italic;font-weight:500;font-size:clamp(1.45rem,3.3vw,2.5rem);color:var(--cream);max-width:30ch;margin:0 auto;line-height:1.3;letter-spacing:.01em;text-align:center}
.title-lg.addr{font-family:var(--addr);font-weight:400;letter-spacing:0;line-height:1.1;font-size:clamp(2.4rem,5.2vw,3.7rem)}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{text-align:center;padding:40px 20px;border-top:1px solid var(--line-soft);color:var(--muted-2);font-size:.78rem;letter-spacing:.05em}
.footer-links{margin-top:10px}
.footer-links a{color:var(--muted);transition:.3s}
.footer-links a:hover{color:var(--cream)}
.legal{max-width:820px;margin:0 auto;padding:150px 24px 90px}
.legal h1{font-family:var(--serif-display);font-weight:400;font-size:clamp(2rem,5vw,2.8rem);margin-bottom:.3rem;color:var(--white)}
.legal h2{font-family:var(--serif);font-weight:400;font-size:1.3rem;margin:2.4rem 0 .7rem;color:var(--white)}
.legal p,.legal li{color:var(--muted);font-size:.95rem;margin-bottom:.8rem;line-height:1.8}
.legal ul{padding-left:20px;margin-bottom:.8rem}
.legal a{color:var(--cream);text-decoration:underline}
.legal .ph{color:var(--cream-2);font-style:italic}
.legal .back{display:inline-block;margin-top:2.6rem;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--cream);border:1px solid var(--line);padding:12px 22px}
.legal .back:hover{border-color:var(--cream)}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:900px){
  .nav-links{
    position:fixed;top:0;right:0;height:100vh;width:74%;max-width:320px;
    flex-direction:column;justify-content:center;gap:34px;
    background:rgba(7,11,20,.97);backdrop-filter:blur(14px);
    transform:translateX(100%);transition:transform .45s ease;
  }
  .nav-links.open{transform:none}
  .nav-links a{font-size:14px}
  .nav-burger{display:flex;z-index:901}
  .pourquoi-grid,.apropos-grid,.contact-grid{grid-template-columns:1fr}
  .apropos-img{order:-1;max-width:420px}
  .services-grid{grid-template-columns:1fr;max-width:460px}
  .tarifs-grid{grid-template-columns:1fr;max-width:480px}
  .timeline{grid-template-columns:1fr 1fr;gap:40px 24px}
  .timeline-line{display:none}
  .port-grid{grid-template-columns:1fr 1fr;grid-auto-rows:220px}
  .port-item.featured{grid-row:span 2}
  body.has-cursor{cursor:auto}
  .cursor-star{display:none}
}
@media(max-width:540px){
  .timeline{grid-template-columns:1fr;max-width:300px}
  .port-grid{grid-template-columns:1fr;grid-auto-rows:240px}
  .port-item.featured{grid-row:span 1}
  .hero-title{font-size:clamp(2.6rem,12vw,3.4rem)}
}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  *{animation-duration:.001s!important}
}
