/* ===== CANASTUDIOS PREMIUM STYLES ===== */


/* ===== VARIABLES ===== */
:root {
  --bg:       #060B16;
  --bg-2:     #090E1C;
  --bg-3:     #0D1528;
  --bg-4:     #121C35;
  --navy:     #1B2A5A;
  --navy-2:   #243775;
  --red:      #E31E24;
  --red-2:    #FF3A40;
  --red-glow: rgba(227,30,36,0.25);
  --white:    #EEF2FF;
  --white-dim:rgba(238,242,255,0.65);
  --white-ghost:rgba(238,242,255,0.07);
  --border:   rgba(27,42,90,0.6);
  --border-red:rgba(227,30,36,0.35);
  --glass:    rgba(9,14,28,0.85);
  --font-display:'Syne', sans-serif;
  --font-body:   'Barlow', sans-serif;
  --shadow-red:  0 0 60px rgba(227,30,36,0.2);
  --shadow-navy: 0 0 60px rgba(27,42,90,0.4);
  --transition:  all 0.4s cubic-bezier(0.25,0.46,0.45,0.94);
  --radius:      3px;
}

/* ===== RESET ===== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;font-size:16px;}
body{
  background:var(--bg);
  color:var(--white);
  font-family:var(--font-body);
  font-weight:300;
  line-height:1.6;
  overflow-x:hidden;
  cursor:none;
}
a{text-decoration:none;color:inherit;}
img{max-width:100%;display:block;}
button{cursor:none;border:none;background:none;font-family:var(--font-body);}
input,textarea,select{font-family:var(--font-body);}
::selection{background:var(--red);color:#fff;}

/* ===== CURSOR ===== */
.cursor{
  width:10px;height:10px;
  background:var(--red);
  border-radius:50%;
  position:fixed;top:0;left:0;
  pointer-events:none;z-index:99999;
  transform:translate(-50%,-50%);
  transition:width .2s,height .2s;
  mix-blend-mode:normal;
}
.cursor-ring{
  width:36px;height:36px;
  border:1px solid var(--red);
  border-radius:50%;
  position:fixed;top:0;left:0;
  pointer-events:none;z-index:99998;
  transform:translate(-50%,-50%);
  opacity:.5;
  transition:transform .14s ease,width .3s,height .3s;
}
.cursor.big{width:6px;height:6px;}
.cursor-ring.big{width:54px;height:54px;opacity:.8;}

/* ===== GRAIN ===== */
.grain{
  position:fixed;inset:-50%;
  width:200%;height:200%;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
  pointer-events:none;z-index:9999;
  opacity:.5;
  animation:grain 6s steps(2) infinite;
}
@keyframes grain{
  0%,100%{transform:translate(0,0);}
  10%{transform:translate(-2%,-3%);}
  20%{transform:translate(3%,1%);}
  30%{transform:translate(-1%,4%);}
  40%{transform:translate(4%,-2%);}
  50%{transform:translate(-3%,3%);}
  60%{transform:translate(2%,-4%);}
  70%{transform:translate(-4%,0);}
  80%{transform:translate(3%,2%);}
  90%{transform:translate(-1%,-2%);}
}

/* ===== LOADER ===== */
#loader{
  position:fixed;inset:0;
  background:var(--bg);
  z-index:99997;
  display:flex;align-items:center;justify-content:center;flex-direction:column;gap:2.5rem;
  transition:opacity .9s ease,visibility .9s ease;
}
#loader.hidden{opacity:0;visibility:hidden;}
.loader-logo{width:180px;opacity:0;animation:fadeUp .8s .2s forwards;}
.loader-tagline{
  font-family:var(--font-display);
  font-size:.65rem;letter-spacing:.5em;text-transform:uppercase;
  color:rgba(238,242,255,.4);
  opacity:0;animation:fadeUp .8s .5s forwards;
}
.loader-progress{
  width:160px;height:1px;
  background:rgba(27,42,90,.5);
  position:relative;overflow:hidden;
}
.loader-progress::after{
  content:'';position:absolute;top:0;left:-100%;
  width:100%;height:100%;
  background:linear-gradient(90deg,var(--navy),var(--red));
  animation:loadBar 1.8s .4s ease forwards;
}
@keyframes loadBar{to{left:0;}}

/* ===== WAVEFORM BARS (hero decoration) ===== */
.wave-bars{
  display:flex;align-items:center;gap:3px;
  height:50px;
}
.wave-bar{
  width:3px;
  background:var(--red);
  border-radius:2px;
  animation:wavePulse 1.2s ease-in-out infinite;
  opacity:.7;
}
.wave-bar:nth-child(1){height:20px;animation-delay:0s;}
.wave-bar:nth-child(2){height:35px;animation-delay:.1s;}
.wave-bar:nth-child(3){height:50px;animation-delay:.2s;}
.wave-bar:nth-child(4){height:30px;animation-delay:.3s;}
.wave-bar:nth-child(5){height:45px;animation-delay:.15s;}
.wave-bar:nth-child(6){height:25px;animation-delay:.25s;}
.wave-bar:nth-child(7){height:40px;animation-delay:.05s;}
.wave-bar:nth-child(8){height:18px;animation-delay:.35s;}
.wave-bar:nth-child(9){height:42px;animation-delay:.2s;}
.wave-bar:nth-child(10){height:28px;animation-delay:.1s;}
.wave-bar:nth-child(11){height:50px;animation-delay:.3s;}
.wave-bar:nth-child(12){height:22px;animation-delay:0s;}
@keyframes wavePulse{
  0%,100%{transform:scaleY(1);opacity:.5;}
  50%{transform:scaleY(.35);opacity:1;}
}

/* ===== NAVBAR ===== */
#navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:1.8rem 5rem;
  display:flex;align-items:center;justify-content:space-between;
  transition:var(--transition);
}
#navbar.scrolled{
  background:rgba(6,11,22,.95);
  backdrop-filter:blur(20px);
  padding:1rem 5rem;
  border-bottom:1px solid var(--border);
  box-shadow:0 4px 40px rgba(0,0,0,.5);
}
.nav-logo{height:44px;}
.nav-links{display:flex;gap:2.5rem;list-style:none;}
.nav-links a{
  font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--white-dim);transition:var(--transition);position:relative;
}
.nav-links a::after{
  content:'';position:absolute;bottom:-4px;left:0;
  width:0;height:1px;background:var(--red);transition:width .3s ease;
}
.nav-links a:hover{color:var(--white);}
.nav-links a:hover::after{width:100%;}
.nav-cta{
  background:var(--red);
  color:#fff !important;
  padding:.65rem 1.6rem;
  font-size:.72rem !important;font-weight:600 !important;
  letter-spacing:.15em;text-transform:uppercase;
  transition:var(--transition) !important;
}
.nav-cta::after{display:none !important;}
.nav-cta:hover{background:var(--red-2);box-shadow:var(--shadow-red);transform:translateY(-2px);}
.hamburger{display:none;flex-direction:column;gap:5px;}
.hamburger span{width:26px;height:1px;background:var(--red);transition:var(--transition);}

/* ===== HERO ===== */
#hero{
  position:relative;height:100vh;min-height:700px;
  display:flex;align-items:center;overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;
  background:url('../images/hero-studio.jpg') center/cover no-repeat;
  transform:scale(1.06);
  transition:transform 8s ease;
}
.hero-bg::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(6,11,22,.96) 0%,rgba(6,11,22,.82) 60%,rgba(6,11,22,.92) 100%);
}
/* Red glow bottom */
.hero-bg::before{
  content:'';position:absolute;
  bottom:-100px;left:50%;transform:translateX(-50%);
  width:600px;height:300px;
  background:radial-gradient(ellipse,rgba(227,30,36,.12) 0%,transparent 70%);
  pointer-events:none;
}
.hero-scan-lines{
  position:absolute;inset:0;
  background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(238,242,255,.012) 3px,rgba(238,242,255,.012) 4px);
  pointer-events:none;
}
.hero-content{
  position:relative;z-index:2;
  padding:0 5rem;max-width:750px;
  margin-top:5rem;
}
.hero-tag{
  display:inline-flex;align-items:center;gap:.7rem;
  font-size:.65rem;letter-spacing:.4em;text-transform:uppercase;
  color:var(--red);margin-bottom:1.5rem;
  opacity:0;animation:fadeUp .8s 2.4s forwards;
}
.hero-tag .dot{width:6px;height:6px;background:var(--red);border-radius:50%;animation:blink 1.5s infinite;}
@keyframes blink{0%,100%{opacity:1;}50%{opacity:.2;}}
.hero-title{
  font-family:var(--font-display);
  font-size:clamp(3.2rem,7vw,6rem);
  font-weight:800;line-height:1;
  letter-spacing:-.02em;
  text-transform:uppercase;
  margin-bottom:1.5rem;
  opacity:0;animation:fadeUp .9s 2.6s forwards;
}
.hero-title .accent{color:var(--red);display:block;}
.hero-title .outline{
  -webkit-text-stroke:1px rgba(238,242,255,.4);
  color:transparent;display:block;
}
.hero-sub{
  font-size:1rem;font-weight:300;
  color:var(--white-dim);
  max-width:480px;margin-bottom:3rem;
  line-height:1.9;
  opacity:0;animation:fadeUp .9s 2.8s forwards;
}
.hero-wave{
  margin-bottom:2.5rem;
  opacity:0;animation:fadeUp .8s 2.9s forwards;
}
.hero-actions{
  display:flex;gap:1.2rem;flex-wrap:wrap;
  opacity:0;animation:fadeUp .9s 3s forwards;
}
.btn-primary{
  background:var(--red);color:#fff;
  padding:1rem 2.4rem;
  font-family:var(--font-display);
  font-size:.78rem;font-weight:700;
  letter-spacing:.15em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:.6rem;
  transition:var(--transition);position:relative;overflow:hidden;
}
.btn-primary::before{
  content:'';position:absolute;inset:0;
  background:rgba(255,255,255,.15);
  transform:translateX(-100%);transition:transform .4s ease;
}
.btn-primary:hover::before{transform:translateX(100%);}
.btn-primary:hover{background:var(--red-2);box-shadow:var(--shadow-red);transform:translateY(-3px);}
.btn-outline{
  background:transparent;color:var(--white);
  padding:1rem 2.4rem;
  font-family:var(--font-display);
  font-size:.78rem;font-weight:600;
  letter-spacing:.15em;text-transform:uppercase;
  border:1px solid var(--border);
  display:inline-flex;align-items:center;gap:.6rem;
  transition:var(--transition);
}
.btn-outline:hover{border-color:var(--red);color:var(--red);box-shadow:0 0 20px rgba(227,30,36,.1);}
.hero-scroll{
  position:absolute;bottom:3rem;left:5rem;
  display:flex;align-items:center;gap:.8rem;
  font-size:.6rem;letter-spacing:.35em;text-transform:uppercase;
  color:var(--white-dim);
  opacity:0;animation:fadeUp .8s 3.3s forwards;
}
.hero-scroll::before{
  content:'';width:40px;height:1px;
  background:linear-gradient(to right,transparent,var(--white-dim));
}
.hero-num{
  position:absolute;bottom:3rem;right:5rem;
  font-family:var(--font-display);font-size:7rem;font-weight:800;
  color:rgba(27,42,90,.15);line-height:1;
  opacity:0;animation:fadeUp .8s 3.2s forwards;
  pointer-events:none;
  letter-spacing:-.05em;
}

/* ===== MARQUEE ===== */
.marquee-wrap{
  background:var(--red);
  padding:.85rem 0;overflow:hidden;
}
.marquee-track{
  display:flex;gap:3rem;
  animation:ticker 22s linear infinite;
  white-space:nowrap;
}
.marquee-item{
  display:flex;align-items:center;gap:.8rem;
  font-family:var(--font-display);
  font-size:.68rem;font-weight:700;letter-spacing:.25em;text-transform:uppercase;
  color:#fff;flex-shrink:0;
}
.marquee-item::before{content:'●';font-size:.3rem;opacity:.8;}
@keyframes ticker{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ===== COMMON SECTION ===== */
section{position:relative;}
.sec{padding:7rem 5rem;}
.sec-tag{
  display:inline-flex;align-items:center;gap:.7rem;
  font-size:.62rem;letter-spacing:.4em;text-transform:uppercase;
  color:var(--red);margin-bottom:1rem;
}
.sec-tag::before{content:'';width:24px;height:1px;background:var(--red);}
.sec-title{
  font-family:var(--font-display);
  font-size:clamp(2rem,4.5vw,3.5rem);
  font-weight:800;text-transform:uppercase;
  line-height:1.05;letter-spacing:-.02em;
  margin-bottom:1rem;
}
.sec-title .red{color:var(--red);}
.sec-title .dim{color:rgba(238,242,255,.35);}
.sec-sub{
  font-size:.95rem;color:var(--white-dim);
  max-width:500px;line-height:1.9;
}
.line{
  width:50px;height:2px;
  background:var(--red);
  margin:1.2rem 0;
}

/* ===== SERVICES ===== */
#services{background:var(--bg-2);}
.services-head{
  display:grid;grid-template-columns:1fr 1fr;
  gap:3rem;align-items:end;margin-bottom:4rem;
  flex-wrap:wrap;
}
.services-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1px;background:var(--border);
}
.svc-card{
  background:var(--bg-2);
  position:relative;overflow:hidden;
  transition:var(--transition);
}
.svc-card:hover{background:var(--bg-3);}
.svc-img-wrap{height:240px;overflow:hidden;position:relative;}
.svc-img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .7s ease;
  filter:brightness(.5) saturate(.7);
}
.svc-card:hover .svc-img{transform:scale(1.06);filter:brightness(.65) saturate(.9);}
.svc-num{
  position:absolute;top:1.5rem;right:1.5rem;
  font-family:var(--font-display);
  font-size:.65rem;letter-spacing:.2em;
  color:var(--red);
  background:rgba(6,11,22,.8);
  padding:.3rem .7rem;
}
.svc-body{padding:2.5rem 2.2rem;}
.svc-icon{font-size:1.8rem;margin-bottom:.8rem;display:block;}
.svc-name{
  font-family:var(--font-display);
  font-size:1.3rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.04em;margin-bottom:.6rem;
}
.svc-desc{font-size:.85rem;color:var(--white-dim);line-height:1.8;}
.svc-link{
  display:inline-flex;align-items:center;gap:.5rem;
  font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;
  color:var(--red);margin-top:1.2rem;
  font-family:var(--font-display);font-weight:600;
  transition:var(--transition);
}
.svc-link:hover{gap:1rem;}
.svc-card::before{
  content:'';position:absolute;
  top:0;left:0;right:0;height:2px;
  background:var(--red);
  transform:scaleX(0);transition:transform .4s ease;
}
.svc-card:hover::before{transform:scaleX(1);}

/* ===== VISION ===== */
#vision{
  background:var(--bg-3);
  overflow:hidden;
}
.vision-wrap{
  display:grid;grid-template-columns:1fr 1fr;
  gap:6rem;align-items:center;
}
.vision-img-col{position:relative;}
.vision-img-main{
  width:100%;height:500px;
  object-fit:cover;
  filter:brightness(.7) saturate(.8);
  position:relative;z-index:1;
}
.vision-img-accent{
  position:absolute;
  bottom:-2rem;right:-2rem;
  width:200px;height:150px;
  object-fit:cover;
  border:3px solid var(--red);
  z-index:2;
  filter:brightness(.8);
}
.vision-badge{
  position:absolute;
  top:2rem;left:-1.5rem;
  background:var(--red);
  padding:1.2rem 1.5rem;
  z-index:3;
  text-align:center;
}
.vision-badge-num{
  font-family:var(--font-display);
  font-size:2rem;font-weight:800;
  line-height:1;color:#fff;
  display:block;
}
.vision-badge-text{
  font-size:.6rem;letter-spacing:.15em;text-transform:uppercase;
  color:rgba(255,255,255,.8);
}
.vision-text{}
.vision-quote{
  font-family:var(--font-display);
  font-size:clamp(1.3rem,2.5vw,1.8rem);
  font-weight:600;line-height:1.4;
  color:var(--white);
  margin:2rem 0;
  padding-left:1.5rem;
  border-left:3px solid var(--red);
  font-style:italic;
}
.vision-body{font-size:.95rem;color:var(--white-dim);line-height:1.9;margin-bottom:2rem;}

/* ===== PROCESS ===== */
#process{background:var(--bg);}
.process-steps{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:0;margin-top:4rem;
  position:relative;
}
.process-steps::before{
  content:'';
  position:absolute;
  top:2.8rem;left:12.5%;right:12.5%;
  height:1px;
  background:linear-gradient(to right,var(--navy),var(--red),var(--navy));
  opacity:.5;
}
.process-step{padding:2rem;text-align:center;}
.step-num{
  width:56px;height:56px;
  background:var(--bg-3);
  border:1px solid var(--border);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);
  font-size:1rem;font-weight:700;
  color:var(--white-dim);
  margin:0 auto 1.8rem;
  transition:var(--transition);
  position:relative;z-index:1;
}
.process-step:hover .step-num{
  border-color:var(--red);
  color:var(--red);
  box-shadow:var(--shadow-red);
  background:var(--bg-4);
}
.step-title{
  font-family:var(--font-display);
  font-size:1rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.05em;margin-bottom:.6rem;
}
.step-desc{font-size:.82rem;color:var(--white-dim);line-height:1.7;}

/* ===== PORTFOLIO ===== */
#portfolio{background:var(--bg-2);overflow:hidden;}
.portfolio-head{
  display:flex;justify-content:space-between;align-items:flex-end;
  margin-bottom:3rem;flex-wrap:wrap;gap:2rem;
}
.portfolio-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr;
  grid-template-rows:280px 280px;
  gap:3px;
}
.p-item{overflow:hidden;position:relative;}
.p-item:first-child{grid-row:span 2;}
.p-img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .7s ease;
  filter:brightness(.55) saturate(.6);
}
.p-item:hover .p-img{transform:scale(1.05);filter:brightness(.75) saturate(.9);}
.p-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(6,11,22,.9) 0%,transparent 60%);
  opacity:0;transition:opacity .4s ease;
  display:flex;align-items:flex-end;padding:1.8rem;
}
.p-item:hover .p-overlay{opacity:1;}
.p-label{
  font-family:var(--font-display);
  font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--red);
}

/* ===== REVIEWS ===== */
#reviews{background:var(--bg-3);}
.google-strip{
  display:inline-flex;align-items:center;gap:1rem;
  background:var(--bg-4);border:1px solid var(--border);
  padding:.7rem 1.4rem;margin-bottom:2.5rem;
  font-size:.8rem;
}
.google-g{
  width:28px;height:28px;
  background:linear-gradient(135deg,#4285F4,#34A853,#FBBC05,#EA4335);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:.8rem;color:#fff;flex-shrink:0;
}
.reviews-stars-overall{color:#FFC107;font-size:1rem;letter-spacing:.1em;}
.reviews-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1.5rem;
}
.r-card{
  background:var(--bg-2);
  border:1px solid var(--border);
  padding:2rem;
  transition:var(--transition);
  position:relative;
}
.r-card:hover{border-color:rgba(227,30,36,.4);box-shadow:var(--shadow-red);transform:translateY(-5px);}
.r-stars{color:#FFC107;font-size:.85rem;margin-bottom:.8rem;}
.r-text{
  font-size:.875rem;color:var(--white-dim);
  line-height:1.8;font-style:italic;margin-bottom:1.5rem;
}
.r-author{display:flex;align-items:center;gap:.9rem;}
.r-avatar{
  width:40px;height:40px;border-radius:50%;
  background:linear-gradient(135deg,var(--navy),var(--red));
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-weight:700;font-size:.9rem;
  flex-shrink:0;
}
.r-name{font-size:.85rem;font-weight:500;}
.r-date{font-size:.72rem;color:var(--white-dim);}
.r-g-icon{
  position:absolute;top:1.2rem;right:1.2rem;
  opacity:.3;font-size:1rem;
  background:linear-gradient(135deg,#4285F4,#EA4335);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

/* ===== CONTACT ===== */
#contact{background:var(--bg);}
.contact-wrap{
  display:grid;grid-template-columns:1fr 1fr;
  gap:5rem;align-items:start;
}
.contact-info{}
.contact-details{margin:2.5rem 0;}
.c-detail{
  display:flex;gap:1.5rem;
  padding:1.5rem 0;
  border-bottom:1px solid var(--border);
}
.c-detail:last-child{border-bottom:none;}
.c-icon{
  width:44px;height:44px;
  border:1px solid var(--border-red);
  display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;color:var(--red);flex-shrink:0;
}
.c-label{
  font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--red);margin-bottom:.3rem;
}
.c-val{font-size:.9rem;line-height:1.6;}
.c-val a{color:var(--white);transition:color .3s;}
.c-val a:hover{color:var(--red);}
.contact-social{
  display:flex;gap:.7rem;margin-top:2rem;
}
.soc-btn{
  width:40px;height:40px;
  border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  font-size:.9rem;color:var(--white-dim);
  transition:var(--transition);
}
.soc-btn:hover{border-color:var(--red);color:var(--red);box-shadow:0 0 15px rgba(227,30,36,.15);}
.contact-form-box{
  background:var(--bg-2);
  border:1px solid var(--border);
  padding:3rem;
  position:relative;
}
.contact-form-box::before{
  content:'';position:absolute;
  top:0;left:20px;right:20px;height:2px;
  background:linear-gradient(90deg,transparent,var(--red),transparent);
}
.form-group{margin-bottom:1.2rem;}
.form-group label{
  display:block;font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--red);margin-bottom:.5rem;
}
.form-group input,
.form-group select,
.form-group textarea{
  width:100%;background:var(--bg-3);
  border:1px solid var(--border);
  color:var(--white);padding:.85rem 1.1rem;
  font-size:.9rem;outline:none;resize:none;
  transition:var(--transition);
  appearance:none;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{
  border-color:var(--red);
  box-shadow:0 0 0 3px rgba(227,30,36,.08);
}
.form-group input::placeholder,
.form-group textarea::placeholder{color:rgba(238,242,255,.25);}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.btn-submit{
  width:100%;background:var(--red);color:#fff;
  padding:1rem;font-family:var(--font-display);
  font-size:.78rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;
  border:none;margin-top:.5rem;transition:var(--transition);
  display:flex;align-items:center;justify-content:center;gap:.6rem;
}
.btn-submit:hover{background:var(--red-2);box-shadow:var(--shadow-red);}

/* ===== FOOTER ===== */
#footer{
  background:var(--bg-2);
  border-top:1px solid var(--border);
  padding:4.5rem 5rem 2rem;
}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr;
  gap:4rem;margin-bottom:3.5rem;
}
.footer-logo{height:44px;margin-bottom:1.2rem;}
.footer-tagline{
  font-size:.85rem;color:var(--white-dim);
  line-height:1.9;max-width:270px;margin-bottom:1.5rem;
}
.footer-col h5{
  font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--red);margin-bottom:1.3rem;
}
.footer-links{list-style:none;}
.footer-links li{margin-bottom:.7rem;}
.footer-links a{
  font-size:.85rem;color:var(--white-dim);transition:var(--transition);
}
.footer-links a:hover{color:var(--red);}
.footer-contact-list{list-style:none;}
.footer-contact-list li{
  font-size:.82rem;color:var(--white-dim);
  margin-bottom:.6rem;
  display:flex;align-items:flex-start;gap:.5rem;
}
.footer-contact-list a{color:var(--red);}
.footer-bottom{
  border-top:1px solid var(--border);
  padding-top:1.8rem;
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:1rem;
}
.footer-copy{font-size:.72rem;color:rgba(238,242,255,.4);}
.footer-legal{display:flex;gap:2rem;list-style:none;}
.footer-legal a{font-size:.72rem;color:rgba(238,242,255,.4);transition:color .3s;}
.footer-legal a:hover{color:var(--red);}

/* ===== MOBILE NAV ===== */
.mobile-nav{
  position:fixed;inset:0;
  background:rgba(6,11,22,.98);
  z-index:999;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:2.5rem;
  opacity:0;visibility:hidden;transition:var(--transition);
}
.mobile-nav.open{opacity:1;visibility:visible;}
.mobile-nav a{
  font-family:var(--font-display);
  font-size:2.2rem;font-weight:800;text-transform:uppercase;
  color:var(--white-dim);letter-spacing:.05em;transition:var(--transition);
}
.mobile-nav a:hover{color:var(--red);}

/* ===== TOAST ===== */
.toast{
  position:fixed;bottom:2rem;right:2rem;
  background:var(--bg-3);
  border:1px solid var(--red);
  border-left:3px solid var(--red);
  padding:1rem 1.5rem;
  font-size:.85rem;max-width:300px;
  z-index:9999;
  transform:translateY(80px);opacity:0;
  transition:var(--transition);
  box-shadow:var(--shadow-red);
}
.toast.show{transform:translateY(0);opacity:1;}

/* ===== REVEAL ===== */
.reveal{opacity:0;transform:translateY(35px);transition:opacity .8s ease,transform .8s ease;}
.reveal.visible{opacity:1;transform:translateY(0);}
.reveal-delay-1{transition-delay:.1s;}
.reveal-delay-2{transition-delay:.2s;}
.reveal-delay-3{transition-delay:.3s;}
.reveal-delay-4{transition-delay:.4s;}
.reveal-delay-5{transition-delay:.5s;}

/* ===== KEYFRAMES ===== */
@keyframes fadeUp{from{opacity:0;transform:translateY(25px);}to{opacity:1;transform:translateY(0);}}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}

/* ===== SCROLLBAR ===== */
::-webkit-scrollbar{width:3px;}
::-webkit-scrollbar-track{background:var(--bg);}
::-webkit-scrollbar-thumb{background:var(--navy);}
::-webkit-scrollbar-thumb:hover{background:var(--red);}

/* ===== RESPONSIVE ===== */
@media(max-width:1100px){
  .sec{padding:5rem 3rem;}
  #navbar,#navbar.scrolled{padding-left:3rem;padding-right:3rem;}
  .hero-content{padding:0 3rem;}
  .hero-num{right:3rem;}
  .hero-scroll{left:3rem;}
  .vision-wrap{grid-template-columns:1fr;gap:3rem;}
  .vision-img-accent{display:none;}
  .contact-wrap{grid-template-columns:1fr;gap:3rem;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:3rem;}
  .process-steps{grid-template-columns:repeat(2,1fr);}
  .process-steps::before{display:none;}
}
@media(max-width:800px){
  .services-grid{grid-template-columns:1fr;}
  .reviews-grid{grid-template-columns:1fr;}
  .portfolio-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto;}
  .portfolio-grid .p-item:first-child{grid-row:span 1;}
  .nav-links{display:none;}
  .hamburger{display:flex;}
  .hero-stats-bar{display:none;}
  .footer-grid{grid-template-columns:1fr;}
  .services-head{grid-template-columns:1fr;}
  .form-row{grid-template-columns:1fr;}
}
@media(max-width:560px){
  .sec{padding:4rem 1.5rem;}
  #navbar,#navbar.scrolled{padding-left:1.5rem;padding-right:1.5rem;}
  .hero-content{padding:0 1.5rem;}
  .hero-scroll,.hero-num{display:none;}
  .hero-actions{flex-direction:column;}
  .btn-primary,.btn-outline{width:100%;justify-content:center;}
  .portfolio-grid{grid-template-columns:1fr;}
}
