/*
Theme Name: OrbisWorks Theme
Theme URI: https://orbisworkstech.com
Author: OrbisWorks
Author URI: https://orbisworkstech.com
Description: Custom theme for OrbisWorks — a tech company building AI-powered tools and mobile platforms.
Version: 1.0
License: All Rights Reserved
Text Domain: orbisworks
*/

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --bg:#fafafa;
  --bg-alt:#f0f0f5;
  --text:#1a1a2e;
  --text-dim:#6b6b80;
  --white:#ffffff;
  --black:#0d0d14;
  --purple:#7c3aed;
  --blue:#2563eb;
  --cyan:#06b6d4;
  --green:#10b981;
  --orange:#f59e0b;
  --pink:#ec4899;
  --red:#ef4444;
  --grad-hero:linear-gradient(135deg,#7c3aed 0%,#2563eb 30%,#06b6d4 60%,#10b981 100%);
  --grad-zyan:linear-gradient(135deg,#7c3aed,#2563eb,#06b6d4);
  --grad-boat:linear-gradient(135deg,#f59e0b,#ef4444,#ec4899);
  --font:'Sora',system-ui,sans-serif;
  --mono:'Space Mono',monospace;
  --radius:20px;
  --radius-sm:12px;
}

html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:var(--font);
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}

/* NAVBAR */
nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:1rem 2.5rem;
  display:flex;align-items:center;justify-content:space-between;
  background:rgba(250,250,250,.8);
  backdrop-filter:blur(24px) saturate(180%);
  border-bottom:1px solid rgba(0,0,0,.05);
  transition:all .3s;
}
nav.scrolled{padding:.7rem 2.5rem;box-shadow:0 4px 30px rgba(0,0,0,.06)}
.logo{display:flex;align-items:center;gap:.6rem;font-weight:700;font-size:1.2rem;letter-spacing:-.02em}
.logo-orb{
  width:34px;height:34px;border-radius:10px;
  background:var(--grad-hero);
  display:flex;align-items:center;justify-content:center;
  color:white;font-size:.8rem;font-weight:800;
  transform:rotate(-8deg);
  transition:transform .3s;
  box-shadow:0 4px 16px rgba(124,58,237,.3);
}
.logo:hover .logo-orb{transform:rotate(8deg) scale(1.1)}
.nav-mid{display:flex;gap:2rem;align-items:center}
.nav-mid a{
  font-size:.85rem;font-weight:500;color:var(--text-dim);
  position:relative;transition:color .25s;
}
.nav-mid a::after{
  content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;
  background:var(--purple);border-radius:2px;transition:width .25s;
}
.nav-mid a:hover{color:var(--text)}
.nav-mid a:hover::after{width:100%}
.nav-cta{
  padding:.6rem 1.6rem;border-radius:100px;
  background:var(--text);color:white;
  font-size:.82rem;font-weight:600;letter-spacing:.01em;
  transition:transform .2s,box-shadow .2s;
}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.15)}
.burger{display:none;background:none;border:none;cursor:pointer;padding:.3rem}
.burger svg{width:26px;height:26px;stroke:var(--text);stroke-width:2;fill:none}

/* HERO */
.hero{
  min-height:100vh;display:flex;align-items:center;
  padding:8rem 2.5rem 5rem;
  position:relative;overflow:hidden;
}
.hero-bg{
  position:absolute;top:-30%;right:-20%;width:80vw;height:80vw;
  max-width:900px;max-height:900px;
  border-radius:50%;
  background:var(--grad-hero);
  opacity:.12;filter:blur(80px);
  animation:heroBg 12s ease-in-out infinite alternate;
  pointer-events:none;
}
@keyframes heroBg{
  0%{transform:translate(0,0) scale(1)}
  100%{transform:translate(-80px,60px) scale(1.15)}
}
.hero-blob2{
  position:absolute;bottom:-10%;left:-15%;width:50vw;height:50vw;
  max-width:600px;max-height:600px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--orange),var(--pink));
  opacity:.08;filter:blur(80px);
  animation:heroBg2 10s ease-in-out infinite alternate;
  pointer-events:none;
}
@keyframes heroBg2{0%{transform:scale(1)}100%{transform:scale(1.2) translate(40px,-30px)}}
.hero-content{max-width:720px;position:relative;z-index:2}
.hero-pill{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.45rem 1rem .45rem .45rem;
  border-radius:100px;
  background:white;
  border:1px solid rgba(0,0,0,.06);
  box-shadow:0 2px 12px rgba(0,0,0,.04);
  font-size:.78rem;font-weight:500;color:var(--text-dim);
  margin-bottom:2rem;
  animation:fadeIn .7s ease both;
}
.hero-pill .dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--green);
  box-shadow:0 0 8px rgba(16,185,129,.5);
  animation:blink 2s infinite;
}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.4}}
.hero-pill .pill-tag{
  padding:.2rem .6rem;border-radius:100px;
  background:linear-gradient(135deg,var(--purple),var(--blue));
  color:white;font-weight:600;font-size:.7rem;letter-spacing:.02em;
}
@keyframes fadeIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.hero h1{
  font-size:clamp(2.8rem,6.5vw,5.2rem);
  font-weight:800;line-height:1.08;letter-spacing:-.04em;
  margin-bottom:1.5rem;
  animation:fadeIn .7s .1s ease both;
}
.hero h1 .gradient-text{
  background:var(--grad-hero);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.hero p{
  font-size:clamp(1rem,2vw,1.2rem);
  color:var(--text-dim);max-width:520px;
  line-height:1.7;margin-bottom:2.5rem;
  animation:fadeIn .7s .2s ease both;
}
.hero-btns{
  display:flex;gap:.8rem;flex-wrap:wrap;
  animation:fadeIn .7s .3s ease both;
}
.btn-grad{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.9rem 2rem;border-radius:14px;
  background:var(--grad-hero);color:white;
  font-weight:600;font-size:.95rem;
  box-shadow:0 8px 32px rgba(124,58,237,.25);
  transition:transform .2s,box-shadow .2s;
}
.btn-grad:hover{transform:translateY(-3px);box-shadow:0 12px 40px rgba(124,58,237,.35)}
.btn-light{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.9rem 2rem;border-radius:14px;
  background:white;color:var(--text);
  font-weight:600;font-size:.95rem;
  border:1.5px solid rgba(0,0,0,.08);
  transition:transform .2s,border-color .2s;
}
.btn-light:hover{transform:translateY(-3px);border-color:var(--purple)}

/* floating cards */
.hero-visual{
  position:absolute;right:4%;top:50%;transform:translateY(-50%);
  width:380px;height:440px;
  display:flex;flex-direction:column;gap:1rem;
  animation:fadeIn .8s .4s ease both;
}
.float-card{
  padding:1.4rem 1.6rem;border-radius:var(--radius);
  background:white;
  border:1px solid rgba(0,0,0,.05);
  box-shadow:0 8px 40px rgba(0,0,0,.06);
  transition:transform .4s;
}
.float-card:hover{transform:translateY(-4px) rotate(-1deg)}
.float-card.z{animation:floatA 6s ease-in-out infinite}
.float-card.b{animation:floatB 7s ease-in-out infinite}
@keyframes floatA{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-12px) rotate(1deg)}}
@keyframes floatB{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-10px) rotate(-1.5deg)}}
.fc-header{display:flex;align-items:center;gap:.6rem;margin-bottom:.8rem}
.fc-icon{
  width:40px;height:40px;border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;
}
.fc-icon.zi{background:linear-gradient(135deg,rgba(124,58,237,.12),rgba(6,182,212,.12));color:var(--purple)}
.fc-icon.bi{background:linear-gradient(135deg,rgba(245,158,11,.12),rgba(236,72,153,.12));color:var(--orange)}
.fc-name{font-weight:700;font-size:1rem}
.fc-tag{
  display:inline-block;padding:.15rem .55rem;border-radius:6px;
  font-size:.65rem;font-weight:600;letter-spacing:.03em;text-transform:uppercase;
}
.fc-tag.ai{background:rgba(124,58,237,.1);color:var(--purple)}
.fc-tag.mobile{background:rgba(245,158,11,.1);color:var(--orange)}
.fc-desc{font-size:.82rem;color:var(--text-dim);line-height:1.6}
.fc-bar{
  height:6px;border-radius:3px;margin-top:.8rem;overflow:hidden;
  background:rgba(0,0,0,.04);
}
.fc-bar-fill{height:100%;border-radius:3px;width:0;animation:barFill 2s 1s ease forwards}
.fc-bar-fill.z-fill{background:var(--grad-zyan)}
.fc-bar-fill.b-fill{background:var(--grad-boat)}
@keyframes barFill{to{width:100%}}

/* MARQUEE */
.marquee-wrap{
  padding:2.5rem 0;
  border-top:1px solid rgba(0,0,0,.04);
  border-bottom:1px solid rgba(0,0,0,.04);
  overflow:hidden;
  background:white;
}
.marquee{
  display:flex;gap:3rem;align-items:center;
  animation:marquee 20s linear infinite;
  width:max-content;
}
@keyframes marquee{to{transform:translateX(-50%)}}
.marquee span{
  font-family:var(--mono);
  font-size:.8rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--text-dim);opacity:.5;white-space:nowrap;
}
.marquee .sep{color:var(--purple);opacity:.3;font-size:1.2rem}

/* ABOUT */
.about{padding:7rem 2.5rem}
.about .container{max-width:1100px;margin:0 auto}
.section-tag{
  display:inline-flex;align-items:center;gap:.4rem;
  padding:.35rem .9rem;border-radius:8px;
  background:rgba(124,58,237,.08);color:var(--purple);
  font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  margin-bottom:1.2rem;
}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.about-left h2{
  font-size:clamp(2rem,4vw,3rem);font-weight:800;
  line-height:1.12;letter-spacing:-.03em;margin-bottom:1.2rem;
}
.about-left h2 .hl{color:var(--purple)}
.about-left p{color:var(--text-dim);font-size:1.02rem;line-height:1.8;margin-bottom:1.2rem}
.about-values{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.5rem}
.av{
  padding:.5rem 1.1rem;border-radius:100px;
  font-size:.78rem;font-weight:600;
  border:1.5px solid transparent;
  transition:transform .2s;cursor:default;
}
.av:hover{transform:translateY(-2px)}
.av.v1{background:rgba(124,58,237,.08);color:var(--purple);border-color:rgba(124,58,237,.15)}
.av.v2{background:rgba(37,99,235,.08);color:var(--blue);border-color:rgba(37,99,235,.15)}
.av.v3{background:rgba(6,182,212,.08);color:var(--cyan);border-color:rgba(6,182,212,.15)}
.av.v4{background:rgba(16,185,129,.08);color:var(--green);border-color:rgba(16,185,129,.15)}
.av.v5{background:rgba(236,72,153,.08);color:var(--pink);border-color:rgba(236,72,153,.15)}

/* about right */
.about-right{display:flex;flex-direction:column;gap:1rem}
.stat-card{
  padding:1.8rem 2rem;border-radius:var(--radius);
  background:white;
  border:1px solid rgba(0,0,0,.05);
  box-shadow:0 4px 20px rgba(0,0,0,.04);
  display:flex;align-items:center;gap:1.5rem;
  transition:transform .3s;
}
.stat-card:hover{transform:translateX(6px)}
.sc-num{
  font-size:2.8rem;font-weight:800;line-height:1;letter-spacing:-.03em;
  background:var(--grad-hero);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  min-width:80px;
}
.sc-info h4{font-weight:700;font-size:1rem;margin-bottom:.2rem}
.sc-info p{font-size:.82rem;color:var(--text-dim);line-height:1.5}

/* PRODUCTS */
.products{padding:7rem 2.5rem;background:var(--bg-alt)}
.products .container{max-width:1100px;margin:0 auto}
.products-header{text-align:center;margin-bottom:4rem}
.products-header h2{
  font-size:clamp(2rem,4.5vw,3.2rem);font-weight:800;
  line-height:1.1;letter-spacing:-.03em;margin-bottom:1rem;
}
.products-header p{color:var(--text-dim);font-size:1.05rem;max-width:550px;margin:0 auto}

.p-grid{display:flex;flex-direction:column;gap:2rem}
.p-card{
  display:grid;grid-template-columns:1fr 1fr;
  border-radius:24px;overflow:hidden;
  background:white;
  border:1px solid rgba(0,0,0,.05);
  box-shadow:0 8px 40px rgba(0,0,0,.05);
  transition:transform .4s,box-shadow .4s;
}
.p-card:hover{transform:translateY(-6px);box-shadow:0 20px 60px rgba(0,0,0,.08)}
.p-card-visual{
  position:relative;
  display:flex;align-items:center;justify-content:center;
  padding:3rem;min-height:380px;
  overflow:hidden;
}
.p-card-visual.zyan-vis{background:linear-gradient(160deg,#7c3aed,#2563eb,#06b6d4)}
.p-card-visual.boat-vis{background:linear-gradient(160deg,#f59e0b,#ef4444,#ec4899)}
.pcv-inner{text-align:center;color:white;position:relative;z-index:2}
.pcv-emoji{font-size:4rem;margin-bottom:1rem;display:block;filter:drop-shadow(0 8px 20px rgba(0,0,0,.2))}
.pcv-name{font-size:2.2rem;font-weight:800;letter-spacing:-.02em;margin-bottom:.4rem}
.pcv-sub{font-size:.9rem;opacity:.85;font-weight:400}
.geo{position:absolute;border-radius:50%;opacity:.15}
.geo1{width:200px;height:200px;border:3px solid white;top:-30px;right:-40px;animation:spin 15s linear infinite}
.geo2{width:120px;height:120px;background:white;bottom:-20px;left:-20px;opacity:.08;animation:spin 20s linear infinite reverse}
.geo3{width:60px;height:60px;background:white;top:30%;left:15%;opacity:.12;border-radius:12px;animation:spin 10s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

.p-card-info{padding:3rem;display:flex;flex-direction:column;justify-content:center}
.p-card-info h3{font-size:1.6rem;font-weight:700;margin-bottom:.6rem;letter-spacing:-.02em}
.p-card-info .p-desc{font-size:.95rem;color:var(--text-dim);line-height:1.75;margin-bottom:1.5rem}
.p-features{list-style:none;display:flex;flex-direction:column;gap:.7rem;margin-bottom:2rem}
.p-features li{display:flex;align-items:center;gap:.6rem;font-size:.88rem;color:var(--text)}
.pf-dot{
  width:22px;height:22px;border-radius:7px;
  display:flex;align-items:center;justify-content:center;
  font-size:.6rem;font-weight:700;color:white;flex-shrink:0;
}
.pf-dot.zd{background:var(--purple)}
.pf-dot.bd{background:var(--orange)}
.p-link{
  display:inline-flex;align-items:center;gap:.5rem;
  font-weight:700;font-size:.88rem;
  padding:.7rem 1.6rem;border-radius:12px;
  width:fit-content;
  transition:transform .2s,box-shadow .2s;
}
.p-link.zl{background:rgba(124,58,237,.08);color:var(--purple)}
.p-link.zl:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(124,58,237,.15)}
.p-link.bl{background:rgba(245,158,11,.08);color:var(--orange)}
.p-link.bl:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(245,158,11,.15)}

/* BOATMATE SHOWCASE */
.boat-showcase{
  background:linear-gradient(160deg,#0c1a2e,#132d4a,#0c1a2e) !important;
  position:relative;overflow:hidden;
  padding:0 !important;
  min-height:420px !important;
  display:flex !important;
  align-items:stretch !important;
}
.boat-screens{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  width:100%;
  padding:24px;
}
.boat-screen{
  flex:1;
  min-width:0;
  height:100%;
  max-height:380px;
  object-fit:cover;
  object-position:top;
  border-radius:16px;
  box-shadow:0 12px 40px rgba(0,0,0,.4);
  transition:transform .4s;
}
.boat-screen:hover{
  transform:scale(1.03);
  z-index:2;
}
@media(max-width:768px){
  .boat-showcase{min-height:280px !important}
  .boat-screens{gap:8px;padding:16px}
  .boat-screen{max-height:250px;border-radius:12px}
}

/* VISION */
.vision{padding:7rem 2.5rem}
.vision .container{max-width:1100px;margin:0 auto}
.vision-header{text-align:center;margin-bottom:4rem}
.vision-header h2{
  font-size:clamp(2rem,4.5vw,3.2rem);font-weight:800;
  line-height:1.1;letter-spacing:-.03em;margin-bottom:1rem;
}
.vision-header p{color:var(--text-dim);font-size:1.05rem;max-width:500px;margin:0 auto}
.v-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.v-card{
  padding:2.2rem;border-radius:var(--radius);
  background:white;
  border:1.5px solid rgba(0,0,0,.04);
  box-shadow:0 4px 20px rgba(0,0,0,.03);
  transition:transform .3s,border-color .3s;
  position:relative;overflow:hidden;
}
.v-card:hover{transform:translateY(-5px);border-color:rgba(124,58,237,.15)}
.v-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  opacity:0;transition:opacity .3s;
}
.v-card:hover::before{opacity:1}
.v-card:nth-child(1)::before{background:var(--grad-zyan)}
.v-card:nth-child(2)::before{background:linear-gradient(90deg,var(--green),var(--cyan))}
.v-card:nth-child(3)::before{background:var(--grad-boat)}
.v-emoji{
  width:48px;height:48px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;margin-bottom:1.2rem;
}
.v-card:nth-child(1) .v-emoji{background:rgba(124,58,237,.08)}
.v-card:nth-child(2) .v-emoji{background:rgba(6,182,212,.08)}
.v-card:nth-child(3) .v-emoji{background:rgba(245,158,11,.08)}
.v-card h4{font-size:1.15rem;font-weight:700;margin-bottom:.5rem}
.v-card p{font-size:.88rem;color:var(--text-dim);line-height:1.7}

/* CTA */
.cta{padding:6rem 2.5rem;position:relative;overflow:hidden}
.cta-box{
  max-width:900px;margin:0 auto;
  padding:4.5rem 3rem;border-radius:32px;
  background:var(--text);
  color:white;text-align:center;
  position:relative;overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.2);
}
.cta-box::before{
  content:'';position:absolute;top:-50%;right:-30%;width:500px;height:500px;
  border-radius:50%;background:var(--grad-hero);opacity:.15;filter:blur(60px);pointer-events:none;
}
.cta-box::after{
  content:'';position:absolute;bottom:-40%;left:-20%;width:400px;height:400px;
  border-radius:50%;background:var(--grad-boat);opacity:.1;filter:blur(60px);pointer-events:none;
}
.cta-box h2{
  font-size:clamp(1.8rem,4vw,2.8rem);font-weight:800;
  line-height:1.12;letter-spacing:-.03em;margin-bottom:1rem;
  position:relative;z-index:2;
}
.cta-box p{
  font-size:1.05rem;opacity:.7;max-width:460px;margin:0 auto 2.5rem;
  position:relative;z-index:2;line-height:1.7;
}
.cta-btns{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;position:relative;z-index:2}
.cta-btn-w{
  padding:.9rem 2.2rem;border-radius:14px;
  background:white;color:var(--text);
  font-weight:700;font-size:.95rem;
  transition:transform .2s,box-shadow .2s;
}
.cta-btn-w:hover{transform:translateY(-3px);box-shadow:0 12px 32px rgba(255,255,255,.15)}
.cta-btn-o{
  padding:.9rem 2.2rem;border-radius:14px;
  border:1.5px solid rgba(255,255,255,.2);
  color:white;font-weight:600;font-size:.95rem;
  transition:border-color .25s;
}
.cta-btn-o:hover{border-color:rgba(255,255,255,.5)}

/* FOOTER */
footer{
  padding:3.5rem 2.5rem 2rem;
  border-top:1px solid rgba(0,0,0,.05);
  background:white;
}
.footer-inner{max-width:1100px;margin:0 auto}
.footer-top{display:flex;justify-content:space-between;align-items:flex-start;gap:2rem;margin-bottom:2.5rem;flex-wrap:wrap}
.footer-brand .logo{margin-bottom:.8rem}
.footer-brand p{font-size:.85rem;color:var(--text-dim);max-width:280px;line-height:1.6}
.footer-col h5{font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);margin-bottom:.8rem}
.footer-col a{display:block;font-size:.88rem;color:var(--text);margin-bottom:.5rem;transition:color .2s}
.footer-col a:hover{color:var(--purple)}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:1.5rem;border-top:1px solid rgba(0,0,0,.05);
  font-size:.78rem;color:var(--text-dim);
  flex-wrap:wrap;gap:1rem;
}

/* LEGAL PAGES */
.legal-page{
  padding:8rem 2.5rem 5rem;
  min-height:80vh;
}
.legal-container{
  max-width:760px;margin:0 auto;
}
.legal-page h1{
  font-size:clamp(2rem,4vw,3rem);font-weight:800;
  letter-spacing:-.03em;margin-bottom:.5rem;
}
.legal-updated{
  font-size:.85rem;color:var(--text-dim);margin-bottom:2.5rem;
  padding-bottom:1.5rem;border-bottom:1px solid rgba(0,0,0,.06);
}
.legal-content h2{
  font-size:1.3rem;font-weight:700;margin:2rem 0 .8rem;
  letter-spacing:-.01em;
}
.legal-content h3{
  font-size:1.1rem;font-weight:600;margin:1.5rem 0 .6rem;
}
.legal-content p{
  color:var(--text-dim);font-size:.95rem;line-height:1.85;margin-bottom:1rem;
}
.legal-content ul,.legal-content ol{
  color:var(--text-dim);font-size:.95rem;line-height:1.85;
  margin-bottom:1rem;padding-left:1.5rem;
}
.legal-content li{margin-bottom:.4rem}
.legal-content a{color:var(--purple);text-decoration:underline}
.legal-content a:hover{opacity:.8}

/* SCROLL REVEAL */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}
.reveal.vis{opacity:1;transform:translateY(0)}
.reveal-d1{transition-delay:.1s}
.reveal-d2{transition-delay:.2s}
.reveal-d3{transition-delay:.3s}

/* RESPONSIVE */
@media(max-width:1024px){
  .hero-visual{display:none}
  .hero-content{max-width:100%}
}
@media(max-width:768px){
  nav{padding:.8rem 1.2rem}
  .nav-mid{
    display:none;flex-direction:column;
    position:absolute;top:100%;left:0;right:0;
    background:rgba(250,250,250,.97);backdrop-filter:blur(20px);
    padding:1.5rem;gap:1.2rem;
    border-bottom:1px solid rgba(0,0,0,.05);
  }
  .nav-mid.open{display:flex}
  .burger{display:block}
  section,.about,.products,.vision,.cta{padding:4rem 1.2rem}
  .about-grid{grid-template-columns:1fr;gap:2.5rem}
  .p-card{grid-template-columns:1fr}
  .p-card-visual{min-height:250px}
  .v-grid{grid-template-columns:1fr}
  .cta-box{padding:3rem 1.5rem;border-radius:24px}
  .footer-top{flex-direction:column}
}