/* ============================================
   JW STUDIO — Global Stylesheet v2
   Dark Premium + Light Mode
   ============================================ */

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

:root{
  --cobalt:#3D6FFF;
  --cobalt-hover:#5685ff;
  --cobalt-dim:rgba(61,111,255,0.08);
  --void:#0A0A0A;
  --surface:#101010;
  --surface-2:#161616;
  --border:#1E1E1E;
  --border-hover:rgba(61,111,255,0.35);
  --text:#F2F2F2;
  --muted:#8A8A8E;
  --muted-2:#4A4A4A;
  --danger:#E8002D;
  --success:#00C48C;
  --ease:cubic-bezier(0.4,0,0.2,1);
  --ease-out:cubic-bezier(0.16,1,0.3,1);
  --maxw:1180px;
  --shadow:0 24px 60px rgba(0,0,0,0.35);
  color-scheme:dark;
}

html[data-theme="light"]{
  --void:#F7F7F8;
  --surface:#FFFFFF;
  --surface-2:#F1F1F4;
  --border:#E4E4E8;
  --border-hover:rgba(61,111,255,0.35);
  --text:#101012;
  --muted:#6B6B72;
  --muted-2:#9B9BA3;
  --cobalt-dim:rgba(61,111,255,0.07);
  --shadow:0 24px 60px rgba(0,0,0,0.08);
  color-scheme:light;
}

html{scroll-behavior:smooth;}
body{
  background:var(--void);
  color:var(--text);
  font-family:'DM Sans',system-ui,sans-serif;
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  transition:background 350ms var(--ease),color 350ms var(--ease);
}

a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
button{font-family:inherit;cursor:pointer;}

a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{
  outline:2px solid var(--cobalt);
  outline-offset:3px;
  border-radius:4px;
}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px;}

.eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:'Syne',sans-serif;font-weight:600;font-size:0.72rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--cobalt);}
.eyebrow::before{content:'';width:24px;height:1px;background:var(--cobalt);}
.section-label{display:flex;align-items:center;gap:12px;font-family:'Syne',sans-serif;font-weight:600;font-size:0.68rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--cobalt);margin-bottom:28px;}
.section-label::before{content:'';width:22px;height:1px;background:var(--cobalt);}
.section-title{font-family:'Syne',sans-serif;font-weight:800;font-size:clamp(2rem,4.5vw,3.4rem);letter-spacing:-0.03em;line-height:1.12;padding-bottom:0.08em;margin-bottom:24px;max-width:20ch;}
.section-intro{font-weight:300;font-size:1.1rem;line-height:1.7;color:var(--muted);max-width:54ch;}
.accent{color:var(--cobalt);}
.accent-italic{color:var(--cobalt);font-style:italic;font-family:'Syne',sans-serif;}

.btn-primary{font-family:'Syne',sans-serif;font-weight:600;font-size:0.95rem;background:var(--cobalt);color:#fff;padding:16px 32px;border-radius:8px;border:none;display:inline-flex;align-items:center;gap:10px;transition:transform 250ms var(--ease-out),background 250ms var(--ease);}
.btn-primary:hover{background:var(--cobalt-hover);transform:translateY(-2px);}
.btn-primary svg{transition:transform 250ms var(--ease-out);}
.btn-primary:hover svg{transform:translateX(4px);}
.btn-secondary{font-family:'Syne',sans-serif;font-weight:600;font-size:0.95rem;color:var(--text);padding:16px 8px;display:inline-flex;align-items:center;gap:10px;transition:color 200ms var(--ease);background:none;border:none;}
.btn-secondary:hover{color:var(--cobalt);}

nav{position:fixed;top:0;left:0;right:0;z-index:100;background:color-mix(in srgb, var(--void) 85%, transparent);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-bottom:.5px solid transparent;transition:border-color 300ms var(--ease),background 350ms var(--ease);}
nav.scrolled{border-bottom-color:var(--border);}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:14px 32px;display:flex;align-items:center;justify-content:space-between;gap:24px;}
.brand img{height:52px;width:auto;}
.nav-links{display:flex;align-items:center;gap:30px;}
.nav-link{font-size:0.9rem;color:var(--muted);transition:color 200ms var(--ease);}
.nav-link:hover,.nav-link.active{color:var(--text);}
.nav-cta{font-family:'Syne',sans-serif;font-weight:600;font-size:0.82rem;background:var(--cobalt);color:#fff;padding:10px 20px;border-radius:6px;transition:transform 200ms var(--ease-out),background 200ms var(--ease);white-space:nowrap;}
.nav-cta:hover{background:var(--cobalt-hover);transform:translateY(-1px);}
.nav-toggle{display:none;background:none;border:none;color:var(--text);font-size:1.6rem;line-height:1;}

.theme-toggle{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:8px;border:.5px solid var(--border);background:var(--surface);color:var(--text);transition:border-color 200ms var(--ease),background 200ms var(--ease);flex-shrink:0;}
.theme-toggle:hover{border-color:var(--border-hover);}
.theme-toggle svg{width:18px;height:18px;}
.theme-toggle .icon-sun{display:none;}
html[data-theme="light"] .theme-toggle .icon-moon{display:none;}
html[data-theme="light"] .theme-toggle .icon-sun{display:block;}

.mobile-menu{display:none;flex-direction:column;gap:4px;padding:8px 32px 24px;background:color-mix(in srgb, var(--void) 98%, transparent);border-bottom:.5px solid var(--border);}
.mobile-menu.open{display:flex;}
.mobile-menu a{padding:14px 0;font-family:'Syne',sans-serif;font-weight:600;font-size:1.1rem;color:var(--text);border-bottom:.5px solid var(--border);}
.mobile-menu a:last-child{border-bottom:none;color:var(--cobalt);}

.section-pad{padding:110px 0;}
.page-top{padding:160px 0 80px;position:relative;}
.page-top .hero-glow{position:absolute;top:10%;left:-10%;width:55%;height:80%;background:radial-gradient(circle,rgba(61,111,255,0.10) 0%,transparent 60%);pointer-events:none;}
.page-h1{font-family:'Syne',sans-serif;font-weight:800;font-size:clamp(2.6rem,6vw,4.6rem);letter-spacing:-0.04em;line-height:1.1;padding-bottom:0.1em;margin-bottom:24px;max-width:16ch;position:relative;}
.page-lead{font-weight:300;font-size:clamp(1.05rem,2vw,1.3rem);line-height:1.6;color:var(--muted);max-width:52ch;position:relative;}

.reveal{opacity:0;transform:translateY(30px);transition:opacity 800ms var(--ease-out),transform 800ms var(--ease-out);}
.reveal.in{opacity:1;transform:translateY(0);}
@keyframes fadeUp{from{opacity:0;transform:translateY(28px);}to{opacity:1;transform:translateY(0);}}

.hero-mesh{position:absolute;inset:0;pointer-events:none;opacity:0.5;background-image:radial-gradient(circle at 20% 20%, rgba(61,111,255,0.10), transparent 35%), radial-gradient(circle at 80% 0%, rgba(124,77,255,0.07), transparent 40%);}
.hero-grain{position:absolute;inset:0;pointer-events:none;opacity:0.035;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

.marquee-wrap{border-top:.5px solid var(--border);border-bottom:.5px solid var(--border);padding:30px 0;overflow:hidden;position:relative;}
.marquee-wrap::before,.marquee-wrap::after{content:'';position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none;}
.marquee-wrap::before{left:0;background:linear-gradient(90deg,var(--void),transparent);}
.marquee-wrap::after{right:0;background:linear-gradient(270deg,var(--void),transparent);}
.marquee-track{display:flex;align-items:center;gap:64px;width:max-content;animation:marquee 28s linear infinite;}
.marquee-wrap:hover .marquee-track{animation-play-state:paused;}
.marquee-item{font-family:'Syne',sans-serif;font-weight:700;font-size:1.1rem;color:var(--muted);letter-spacing:-0.01em;white-space:nowrap;display:flex;align-items:center;gap:10px;}
.marquee-item .dot{width:4px;height:4px;border-radius:50%;background:var(--cobalt);}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}
@media(prefers-reduced-motion:reduce){.marquee-track{animation:none;}}

.trustbar{padding:36px 0;}
.trustbar-inner{display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap;}
.trust-stat{display:flex;flex-direction:column;gap:4px;}
.trust-stat-num{font-family:'Syne',sans-serif;font-weight:800;font-size:2.2rem;color:var(--text);letter-spacing:-0.03em;line-height:1;}
.trust-stat-num span{color:var(--cobalt);}
.trust-stat-label{font-size:0.82rem;color:var(--muted);}

.compare-list{display:flex;flex-direction:column;gap:14px;margin-top:48px;}
.compare-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.compare-cell{display:flex;align-items:flex-start;gap:14px;padding:22px 24px;border-radius:12px;border:.5px solid var(--border);transition:border-color 300ms var(--ease),transform 300ms var(--ease-out);}
.compare-cell:hover{transform:translateY(-2px);}
.compare-cell.bad{background:var(--surface);}
.compare-cell.bad:hover{border-color:rgba(232,0,45,0.3);}
.compare-cell.good{background:linear-gradient(135deg,var(--cobalt-dim),transparent);border-color:rgba(61,111,255,0.2);}
.compare-cell.good:hover{border-color:var(--border-hover);}
.compare-icon{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:0.78rem;margin-top:1px;}
.compare-icon.x{background:rgba(232,0,45,0.12);color:var(--danger);}
.compare-icon.check{background:var(--cobalt);color:#fff;}
.compare-text{font-size:0.96rem;line-height:1.5;}
.compare-cell.bad .compare-text{color:var(--muted);}
.compare-cell.bad .compare-text strong{color:var(--text);font-weight:500;}
.compare-cell.good .compare-text{color:var(--text);}
@media(max-width:760px){.compare-row{grid-template-columns:1fr;}}

.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:56px;background:var(--border);border:.5px solid var(--border);border-radius:16px;overflow:hidden;}
.service{background:var(--void);padding:40px 36px;transition:background 350ms var(--ease);}
.service:hover{background:var(--surface-2);}
.service-icon{width:42px;height:42px;border-radius:10px;background:var(--cobalt-dim);display:flex;align-items:center;justify-content:center;color:var(--cobalt);margin-bottom:22px;}
.service-icon svg{width:20px;height:20px;}
.service-num{font-family:'Syne',sans-serif;font-size:0.7rem;color:var(--cobalt);letter-spacing:0.1em;margin-bottom:8px;}
.service-name{font-family:'Syne',sans-serif;font-weight:700;font-size:1.3rem;letter-spacing:-0.02em;margin-bottom:14px;}
.service-desc{font-size:0.92rem;line-height:1.6;color:var(--muted);}

.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:56px;}
.step-num{font-family:'Syne',sans-serif;font-weight:800;font-size:3rem;color:var(--surface-2);letter-spacing:-0.04em;line-height:1;margin-bottom:16px;transition:color 300ms var(--ease);}
.step:hover .step-num{color:var(--cobalt);}
.step-name{font-family:'Syne',sans-serif;font-weight:700;font-size:1.15rem;margin-bottom:10px;}
.step-desc{font-size:0.9rem;color:var(--muted);line-height:1.6;}

.faq-list{margin-top:48px;border-top:.5px solid var(--border);}
.faq-item{border-bottom:.5px solid var(--border);}
.faq-q{width:100%;background:none;border:none;color:var(--text);font-family:'Syne',sans-serif;font-weight:600;font-size:1.1rem;text-align:left;padding:28px 0;display:flex;align-items:center;justify-content:space-between;gap:20px;transition:color 200ms var(--ease);}
.faq-q:hover{color:var(--cobalt);}
.faq-icon{flex-shrink:0;width:22px;height:22px;position:relative;}
.faq-icon::before,.faq-icon::after{content:'';position:absolute;background:var(--cobalt);border-radius:1px;}
.faq-icon::before{top:50%;left:0;right:0;height:2px;transform:translateY(-50%);}
.faq-icon::after{left:50%;top:0;bottom:0;width:2px;transform:translateX(-50%);transition:opacity 300ms var(--ease);}
.faq-item.open .faq-icon::after{opacity:0;}
.faq-a{max-height:0;overflow:hidden;transition:max-height 400ms var(--ease);}
.faq-a-inner{padding:0 0 28px;font-size:1rem;line-height:1.7;color:var(--muted);max-width:60ch;}

.final-cta{text-align:center;padding:130px 0;position:relative;}
.final-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:80%;height:120%;background:radial-gradient(ellipse,rgba(61,111,255,0.12) 0%,transparent 65%);pointer-events:none;}
.final-cta h2{font-family:'Syne',sans-serif;font-weight:800;font-size:clamp(2.4rem,6vw,4.5rem);letter-spacing:-0.04em;line-height:1.05;padding-bottom:0.08em;margin-bottom:28px;position:relative;}
.final-cta p{font-weight:300;font-size:1.2rem;color:var(--muted);max-width:46ch;margin:0 auto 44px;position:relative;}
.final-reassure{margin-top:24px;font-size:0.85rem;color:var(--muted-2);position:relative;}

footer{border-top:.5px solid var(--border);padding:64px 0 100px;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px;margin-bottom:56px;}
.footer-brand img{height:44px;width:auto;margin-bottom:20px;}
.footer-brand-desc{font-size:0.95rem;color:var(--muted);line-height:1.7;max-width:34ch;}
.footer-col h4{font-family:'Syne',sans-serif;font-weight:600;font-size:0.72rem;letter-spacing:0.16em;text-transform:uppercase;color:var(--muted-2);margin-bottom:20px;}
.footer-col a{display:block;color:var(--muted);font-size:0.92rem;margin-bottom:12px;transition:color 200ms var(--ease);}
.footer-col a:hover{color:var(--text);}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:32px;border-top:.5px solid var(--border);flex-wrap:wrap;gap:16px;}
.footer-copy{font-size:0.8rem;color:var(--muted-2);letter-spacing:0.04em;}

.social-row{display:flex;align-items:center;gap:10px;margin-top:6px;}
.social-icon{width:42px;height:42px;border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform 220ms var(--ease-out),box-shadow 220ms var(--ease);}
.social-icon:hover{transform:translateY(-3px) scale(1.06);box-shadow:0 10px 22px rgba(0,0,0,0.3);}
.social-icon svg{width:100%;height:100%;display:block;}

.wa-float{position:fixed;bottom:24px;right:24px;z-index:90;width:56px;height:56px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);transition:transform 220ms var(--ease-out);animation:waPulse 2.4s ease-out 1s 2;}
.wa-float:hover{transform:scale(1.08);}
.wa-float svg{width:28px;height:28px;fill:#fff;}
@keyframes waPulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,0.55), var(--shadow);}70%{box-shadow:0 0 0 14px rgba(37,211,102,0),var(--shadow);}100%{box-shadow:0 0 0 0 rgba(37,211,102,0),var(--shadow);}}
@media(max-width:560px){.wa-float{bottom:18px;right:18px;width:50px;height:50px;}.wa-float svg{width:24px;height:24px;}}

.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:8px;}
.field{display:flex;flex-direction:column;gap:8px;}
.field.full{grid-column:1 / -1;}
.field label{font-family:'Syne',sans-serif;font-weight:600;font-size:0.8rem;letter-spacing:0.04em;color:var(--text);}
.field input,.field select,.field textarea{background:var(--surface);border:.5px solid var(--border);border-radius:8px;padding:14px 16px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:0.95rem;transition:border-color 200ms var(--ease);}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--cobalt);}
.field input::placeholder,.field textarea::placeholder{color:var(--muted-2);}
.field textarea{resize:vertical;min-height:130px;}
.form-note{font-size:0.82rem;color:var(--muted-2);margin-top:4px;}

.chips{display:flex;flex-wrap:wrap;gap:10px;}
.chip{font-family:'Syne',sans-serif;font-weight:500;font-size:0.85rem;padding:10px 18px;border-radius:100px;border:.5px solid var(--border);background:var(--surface);color:var(--muted);transition:all 200ms var(--ease);}
.chip:hover{border-color:var(--border-hover);color:var(--text);}
.chip.selected{background:var(--cobalt);border-color:var(--cobalt);color:#fff;}

.contact-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:64px;align-items:start;}
.contact-side h3{font-family:'Syne',sans-serif;font-weight:700;font-size:1.4rem;margin-bottom:20px;}
.contact-method{display:flex;align-items:flex-start;gap:14px;margin-bottom:24px;}
.contact-method-icon{width:40px;height:40px;border-radius:8px;background:var(--cobalt-dim);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--cobalt);}
.contact-method-label{font-size:0.78rem;color:var(--muted-2);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:2px;}
.contact-method-value{font-family:'Syne',sans-serif;font-weight:600;font-size:1rem;color:var(--text);}

.work-scroller{display:flex;gap:20px;margin-top:56px;overflow-x:auto;padding-bottom:20px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;}
.work-scroller::-webkit-scrollbar{height:6px;}
.work-scroller::-webkit-scrollbar-track{background:var(--surface);border-radius:10px;}
.work-scroller::-webkit-scrollbar-thumb{background:var(--cobalt);border-radius:10px;}
.work-card{scroll-snap-align:start;flex:0 0 340px;background:var(--surface);border:.5px solid var(--border);border-radius:16px;overflow:hidden;transition:transform 350ms var(--ease-out),border-color 350ms var(--ease);}
.work-card:hover{transform:translateY(-6px);border-color:var(--border-hover);}
.work-thumb{aspect-ratio:16/10;background:radial-gradient(circle at 50% 42%, rgba(61,111,255,0.10), transparent 70%), var(--surface-2);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;}
.work-thumb-logo{max-width:52%;max-height:46%;object-fit:contain;position:relative;z-index:1;filter:drop-shadow(0 6px 16px rgba(0,0,0,0.25));}
.work-thumb-mark{font-family:'Syne',sans-serif;font-weight:800;font-size:2.4rem;color:var(--muted-2);letter-spacing:-0.03em;position:relative;z-index:1;}
.work-thumb-tag{position:absolute;top:16px;left:16px;font-family:'Syne',sans-serif;font-weight:600;font-size:0.7rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--cobalt);background:var(--cobalt-dim);padding:6px 12px;border-radius:100px;z-index:2;}
.work-visit{position:absolute;top:16px;right:16px;width:34px;height:34px;border-radius:50%;background:rgba(0,0,0,0.5);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;color:#fff;opacity:0;transform:translateY(-6px);transition:opacity 250ms var(--ease),transform 250ms var(--ease);z-index:2;}
.work-card:hover .work-visit{opacity:1;transform:translateY(0);}
.work-body{padding:24px 26px;}
.work-title{font-family:'Syne',sans-serif;font-weight:700;font-size:1.2rem;margin-bottom:6px;}
.work-outcome{font-size:0.82rem;color:var(--cobalt);font-weight:500;margin-bottom:10px;}
.work-desc{font-size:0.9rem;color:var(--muted);line-height:1.6;}
.scroller-hint{display:flex;align-items:center;gap:10px;margin-top:18px;font-size:0.8rem;color:var(--muted-2);}
.scroller-hint svg{width:16px;height:16px;animation:scrollHint 1.6s ease-in-out infinite;}
@keyframes scrollHint{0%,100%{transform:translateX(0);}50%{transform:translateX(5px);}}

.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;}
.about-photo{aspect-ratio:4/5;background:var(--surface-2);border:.5px solid var(--border);border-radius:16px;display:flex;align-items:center;justify-content:center;color:var(--muted-2);font-family:'Syne',sans-serif;}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:56px;}
.value-card{background:var(--surface);border:.5px solid var(--border);border-radius:14px;padding:32px;}
.value-word{font-family:'Syne',sans-serif;font-weight:800;font-size:1.5rem;margin-bottom:12px;}
.value-desc{font-size:0.9rem;color:var(--muted);line-height:1.6;}

@media(max-width:900px){
  .nav-links{display:none;}
  .nav-toggle{display:block;}
  .services-grid{grid-template-columns:1fr;}
  .process-grid{grid-template-columns:1fr 1fr;gap:32px;}
  .footer-grid{grid-template-columns:1fr;gap:36px;}
  .contact-grid{grid-template-columns:1fr;gap:40px;}
  .about-grid{grid-template-columns:1fr;gap:40px;}
  .values-grid{grid-template-columns:1fr;}
  .section-pad{padding:80px 0;}
}
@media(max-width:560px){
  .wrap,.nav-inner{padding-left:20px;padding-right:20px;}
  .process-grid{grid-template-columns:1fr;}
  .form-grid{grid-template-columns:1fr;}
  .trustbar-inner{gap:28px;}
  .work-card{flex-basis:280px;}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:0.01ms!important;transition-duration:0.01ms!important;}
  .reveal{opacity:1;transform:none;}
}
