﻿/*
Theme Name: N-BASE Rebuild
*/
:root { --bg:#050505; --fg:#fff; --accent:#F5A000; --accent2:#FFD280; --muted:#BFC7D5; --light:#F7F7F7; }
* { box-sizing:border-box; }
html, body { margin:0; padding:0; background:var(--bg); color:var(--fg); font-family:Arial, sans-serif; }
a { color:inherit; text-decoration:none; }
.nb-container { width:min(1120px, calc(100% - 48px)); margin:0 auto; }
.nb-section { padding:128px 0; }
.nb-light { background:var(--light); color:#000; }
h1,h2,h3,h4,p { margin:0; }
h2 { font-size:clamp(34px, 6vw, 72px); line-height:1.1; letter-spacing:-.02em; margin:10px 0 24px; }

.nb-nav { position:fixed; inset:0 0 auto 0; z-index:60; padding:24px 0; transition:.35s; }
.nb-nav.is-scrolled { padding:16px 0; backdrop-filter:blur(14px); background:rgba(5,5,5,.86); border-bottom:1px solid rgba(255,255,255,.06); }
.nb-nav-row { display:flex; align-items:center; gap:18px; }
.nb-logo { font-size:30px; font-weight:900; color:var(--accent); margin-right:auto; }
.nb-nav-links { display:flex; gap:26px; font-size:12px; font-weight:700; letter-spacing:.18em; }
.nb-nav-links a { color:var(--muted); }
.nb-nav-links a:hover { color:#fff; }
.nb-contact-btn { border-radius:999px; background:var(--accent); color:#000; padding:12px 20px; font-size:12px; font-weight:900; letter-spacing:.16em; }
.nb-menu-btn { display:none; }
.nb-logo-wrap { display:flex; align-items:center; gap:10px; margin-right:auto; }
.nb-logo-divider { width:1px; height:24px; background:rgba(255,255,255,.2); margin-left:4px; }
.nb-logo-sub { color:var(--muted); font-size:10px; letter-spacing:.16em; font-weight:700; line-height:1.2; }
.desktop-only { display:flex; }
.mobile-only { display:none; }
.nb-dd { position:relative; }
.nb-dd > button, .nb-nav-links > a { position:relative; border:none; background:none; color:var(--muted); font-size:12px; font-weight:700; letter-spacing:.18em; display:flex; align-items:center; gap:6px; padding:0; }
.nb-dd > button:hover { color:#fff; }
.nb-nav-links > a:hover { color:#fff; }
.nb-dd > button::after, .nb-nav-links > a::after {
  content:"";
  position:absolute;
  left:0;
  bottom:-6px;
  width:0;
  height:1px;
  background:var(--accent);
  transition:width .3s;
}
.nb-dd > button:hover::after, .nb-nav-links > a:hover::after { width:100%; }
.nb-dd-chevron { font-size:12px; opacity:.6; line-height:1; }
.nb-dd-menu { position:absolute; top:100%; left:50%; transform:translateX(-50%); margin-top:16px; min-width:220px; background:rgba(17,17,17,.92); backdrop-filter:blur(16px); border:1px solid rgba(255,255,255,.12); border-radius:16px; overflow:hidden; box-shadow:0 24px 60px rgba(0,0,0,.7); opacity:0; pointer-events:none; transition:.2s; }
.nb-dd-arrow { position:absolute; top:-6px; left:50%; width:12px; height:12px; background:rgba(17,17,17,.92); border-left:1px solid rgba(255,255,255,.1); border-top:1px solid rgba(255,255,255,.1); transform:translateX(-50%) rotate(45deg); }
.nb-dd.is-open .nb-dd-menu { opacity:1; pointer-events:auto; }
.nb-dd-list { list-style:none; margin:0; padding:8px 0; }
.nb-dd-menu a { display:flex; justify-content:space-between; align-items:center; gap:8px; padding:12px 14px; color:var(--muted); font-size:11px; font-weight:900; letter-spacing:.12em; }
.nb-dd-menu a:hover { color:#fff; background:rgba(255,255,255,.06); }
.nb-nav-note { color:rgba(255,255,255,.3); font-size:9px; letter-spacing:.12em; font-weight:700; }
.nb-mobile-trigger { border:none; background:none; color:#fff; font-size:26px; line-height:1; padding:4px; }

.nb-mobile-menu { position:fixed; inset:0; z-index:100; background:#050505; display:flex; flex-direction:column; }
.nb-mobile-menu[hidden] { display:none !important; }
.nb-mobile-menu .menu-head { display:flex; align-items:center; justify-content:space-between; padding:24px 32px; border-bottom:1px solid rgba(255,255,255,.08); }
.nb-mobile-menu .menu-head strong { color:var(--accent); font-size:24px; letter-spacing:-.02em; }
.nb-mobile-menu .menu-head button { border:none; background:none; color:#fff; font-size:24px; }
.nb-mobile-menu .menu-body { flex:1; overflow:auto; padding:16px 32px; }
.nb-mobile-menu .menu-link, .nb-mobile-menu .menu-acc-toggle { width:100%; border:none; border-bottom:1px solid rgba(255,255,255,.08); background:none; color:#fff; display:flex; justify-content:space-between; align-items:center; padding:16px 0; text-align:left; font-size:24px; letter-spacing:-.02em; font-weight:900; }
.nb-mobile-menu .menu-link small { color:rgba(255,255,255,.25); font-size:10px; letter-spacing:.12em; font-weight:700; }
.nb-mobile-menu .menu-acc-panel { display:none; padding:4px 0 10px 20px; }
.nb-mobile-menu .menu-group.is-open .menu-acc-panel { display:block; }
.nb-mobile-menu .menu-acc-panel a { display:flex; align-items:center; gap:10px; color:var(--muted); font-size:13px; letter-spacing:.12em; font-weight:700; padding:10px 0; }
.nb-mobile-menu .menu-acc-panel a span { width:16px; height:1px; background:rgba(255,255,255,.2); display:inline-block; }
.nb-mobile-menu .menu-foot { padding:16px 32px 28px; border-top:1px solid rgba(255,255,255,.08); }
.nb-mobile-menu .menu-foot .nb-contact-btn { display:flex; justify-content:center; width:100%; padding:18px 22px; }
.nb-mobile-menu .menu-group.is-open .menu-acc-toggle span { transform:rotate(180deg); transition:transform .25s; }

.nb-hero { min-height:100vh; position:relative; display:flex; align-items:center; overflow:hidden; }
.nb-hero::before { content:''; position:absolute; inset:0; z-index:1; background:linear-gradient(to top, #050505, rgba(5,5,5,.2), rgba(5,5,5,.65)); }
.nb-hero-slides, .nb-hero-slide { position:absolute; inset:0; }
.nb-hero-slide { opacity:0; transform:scale(1.1); background-size:cover; background-position:center; filter:brightness(.52); transition:opacity 1.4s, transform 7s; }
.nb-hero-slide.is-active { opacity:1; transform:scale(1); }
.nb-hero-content { position:relative; z-index:2; padding-top:80px; }
.nb-kicker { color:var(--accent); font-size:12px; letter-spacing:.4em; font-weight:900; text-transform:uppercase; }
.nb-kicker.dark { color:#C17A00; }
.nb-hero h1 { font-size:clamp(50px,8vw,88px); margin:16px 0 24px; line-height:1.1; }
.nb-hero h1 span { background:linear-gradient(to right, var(--accent), var(--accent2)); -webkit-background-clip:text; color:transparent; }
.nb-hero-text { max-width:580px; color:rgba(255,255,255,.65); line-height:1.8; }
.hidden-sm { display:none; }
.nb-hero-actions { margin-top:36px; display:flex; align-items:center; gap:24px; }
.nb-primary-btn { background:var(--accent); color:#000; padding:18px 34px; border-radius:999px; font-size:12px; font-weight:900; letter-spacing:.18em; box-shadow:0 0 40px rgba(245,160,0,.38); }
.nb-secondary-link { border-bottom:2px solid rgba(255,255,255,.25); padding-bottom:4px; font-size:12px; letter-spacing:.14em; font-weight:900; }
.nb-hero-label { position:absolute; right:36px; top:36px; z-index:2; font-size:10px; letter-spacing:.3em; color:rgba(255,255,255,.34); font-weight:900; }
.nb-hero-dots { position:absolute; left:50%; transform:translateX(-50%); bottom:92px; z-index:2; display:flex; gap:10px; }
.nb-dot { width:8px; height:8px; border:none; border-radius:999px; background:rgba(255,255,255,.35); }
.nb-dot.is-active { width:32px; background:var(--accent); }
.nb-scroll { position:absolute; left:50%; bottom:36px; transform:translateX(-50%); font-size:10px; letter-spacing:.2em; opacity:.45; z-index:2; }

.nb-grid2 { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.nb-list-cards { margin-top:36px; display:grid; gap:16px; }
.nb-point { background:#fff; border-radius:24px; padding:24px; box-shadow:0 6px 30px rgba(0,0,0,.08); border:1px solid rgba(0,0,0,.06); font-weight:700; }
.nb-image-wrap img { width:100%; aspect-ratio:1/1; object-fit:cover; border-radius:56px; box-shadow:0 30px 80px rgba(0,0,0,.2); }

.nb-center-head { text-align:center; margin-bottom:56px; }
.nb-strength-grid { display:grid; gap:20px; grid-template-columns:repeat(4,1fr); }
.nb-strength-card { background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.08); border-radius:40px; padding:34px; }
.nb-strength-card span { font-size:44px; color:rgba(255,255,255,.2); font-weight:900; }
.nb-strength-card h3 { margin:12px 0; font-size:24px; }
.nb-strength-card p { color:var(--muted); line-height:1.8; font-size:14px; }

.nb-youtube-section { position:relative; overflow:hidden; }
.nb-youtube-glow { position:absolute; left:50%; top:50%; width:700px; height:400px; transform:translate(-50%,-50%); border-radius:999px; background:rgba(245,160,0,.05); filter:blur(120px); pointer-events:none; }
.nb-youtube-wrap { position:relative; z-index:2; }
.nb-youtube-wrap h2 span { background:linear-gradient(to right, var(--accent), var(--accent2)); -webkit-background-clip:text; color:transparent; }
.nb-youtube-copy { color:var(--muted); font-size:20px; line-height:1.8; font-weight:600; }
.nb-youtube-shell { position:relative; }
.nb-youtube-card { position:relative; border-radius:40px; border:1px solid rgba(255,255,255,.08); background:linear-gradient(to bottom right,#111,#0d0d0d,#1a1208); overflow:hidden; aspect-ratio:16/9; box-shadow:0 40px 100px rgba(0,0,0,.7),0 0 0 1px rgba(245,160,0,.08); }
.nb-youtube-shell:hover .nb-youtube-card { transform:translateY(-6px) scale(1.01); transition:.45s ease; }
.nb-youtube-watermark { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-size:8rem; font-weight:900; color:rgba(255,255,255,.03); letter-spacing:-.03em; }
.nb-youtube-overlay-top { position:absolute; left:0; right:0; top:0; height:48px; background:linear-gradient(to bottom, rgba(0,0,0,.6), transparent); }
.nb-youtube-overlay-bottom { position:absolute; left:0; right:0; bottom:0; height:64px; background:linear-gradient(to top, rgba(0,0,0,.8), transparent); }
.nb-youtube-center { position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:20px; }
.nb-play-ring { position:absolute; border-radius:999px; }
.nb-play-ring.ring1 { width:128px; height:128px; background:rgba(245,160,0,.15); animation:ytPulse1 2.4s ease-out infinite; }
.nb-play-ring.ring2 { width:96px; height:96px; background:rgba(245,160,0,.2); animation:ytPulse2 2.4s ease-out infinite .3s; }
.nb-play { width:80px; height:80px; border-radius:999px; background:var(--accent); color:#000; z-index:2; display:flex; align-items:center; justify-content:center; font-weight:900; box-shadow:0 0 50px rgba(245,160,0,.55),0 0 100px rgba(245,160,0,.25); }
.nb-youtube-labels { text-align:center; z-index:2; }
.nb-youtube-labels span { display:block; color:rgba(255,255,255,.4); font-size:12px; letter-spacing:.3em; font-weight:900; text-transform:uppercase; margin-bottom:4px; }
.nb-youtube-labels small { display:block; color:rgba(245,160,0,.5); font-size:10px; letter-spacing:.2em; font-weight:900; text-transform:uppercase; }
.nb-youtube-badge-left, .nb-youtube-badge-right { position:absolute; bottom:20px; font-size:10px; font-weight:900; letter-spacing:.12em; color:rgba(255,255,255,.7); background:rgba(0,0,0,.6); border:1px solid rgba(255,255,255,.1); }
.nb-youtube-badge-left { left:24px; border-radius:999px; padding:7px 10px; display:flex; align-items:center; gap:8px; }
.nb-youtube-badge-right { right:24px; border-radius:6px; padding:4px 8px; color:rgba(255,255,255,.5); }
.nb-youtube-badge-left .dot { width:10px; height:10px; border-radius:999px; background:#f00; display:inline-block; }
.nb-youtube-note { margin-top:20px; text-align:center; font-size:11px; letter-spacing:.25em; font-weight:900; text-transform:uppercase; color:rgba(255,255,255,.2); }

.nb-section-head { margin-bottom:38px; }
.nb-services-head { margin-bottom:80px; display:flex; align-items:flex-end; justify-content:space-between; gap:40px; }
.nb-services-lead { max-width:520px; color:#666; font-size:20px; line-height:1.8; font-weight:600; }
.nb-services-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }
.nb-service-card { position:relative; border-radius:48px; background:#fff; padding:48px; box-shadow:0 8px 30px rgba(0,0,0,.07); min-height:400px; overflow:hidden; display:flex; align-items:flex-end; transition:.35s; }
.nb-service-card:hover { transform:translateY(-8px); box-shadow:0 32px 80px rgba(0,0,0,.12); }
.nb-service-icon { position:absolute; top:48px; right:48px; width:52px; height:52px; border-radius:16px; background:#000; color:#fff; display:flex; align-items:center; justify-content:center; font-weight:900; transition:.35s; }
.nb-service-card:hover .nb-service-icon { background:var(--accent); color:#000; }
.nb-service-text { transform:translateY(22px); transition:.4s; position:relative; z-index:2; }
.nb-service-card:hover .nb-service-text { transform:translateY(0); }
.nb-service-card span { font-size:10px; color:var(--accent); letter-spacing:.3em; font-weight:900; }
.nb-service-card h3 { margin:12px 0 14px; font-size:34px; }
.nb-service-card p { color:#666; line-height:1.8; opacity:0; transition:.45s; }
.nb-service-card:hover p { opacity:1; }
.nb-service-card::after { content:''; position:absolute; inset:0; background:linear-gradient(to top, #fff, rgba(255,255,255,.5), transparent); transition:.35s; }
.nb-service-card:hover::after { background:linear-gradient(to top, rgba(245,160,0,.05), rgba(255,255,255,.5), transparent); }

.nb-works-header { display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:80px; }
.nb-works-viewall-desktop { display:flex; align-items:center; gap:8px; color:var(--muted); font-size:12px; letter-spacing:.2em; font-weight:900; transition:.2s; }
.nb-works-viewall-desktop:hover { color:var(--accent); transform:translateX(4px); }
.nb-works-row { display:flex; gap:32px; overflow:auto; padding:0 24px 32px; scroll-snap-type:x mandatory; }
.nb-work-card { width:300px; flex:0 0 auto; aspect-ratio:4/5; border-radius:48px; overflow:hidden; position:relative; display:block; scroll-snap-align:start; transition:.35s; }
.nb-work-card img { width:100%; height:100%; object-fit:cover; filter:brightness(.75); transition:.75s; }
.nb-work-card:hover { transform:translateY(-12px); }
.nb-work-card:hover img { transform:scale(1.08); }
.nb-work-gradient { position:absolute; inset:0; background:linear-gradient(to top, rgba(0,0,0,.85), rgba(0,0,0,.1), transparent); }
.nb-work-area { position:absolute; top:24px; left:24px; }
.nb-work-area span { background:var(--accent); color:#000; font-size:10px; font-weight:900; letter-spacing:.12em; padding:6px 12px; border-radius:999px; }
.nb-work-arrow { position:absolute; top:24px; right:24px; width:48px; height:48px; border-radius:999px; background:rgba(255,255,255,.1); backdrop-filter:blur(8px); display:flex; align-items:center; justify-content:center; font-size:24px; opacity:0; transition:.3s; }
.nb-work-card:hover .nb-work-arrow { opacity:1; background:var(--accent); color:#000; }
.nb-work-overlay { position:absolute; left:32px; right:32px; bottom:40px; }
.nb-work-overlay span { display:block; font-size:10px; letter-spacing:.3em; color:var(--accent); font-weight:900; margin-bottom:8px; }
.nb-work-overlay h3 { margin:0 0 4px; font-size:32px; letter-spacing:-.02em; transition:.3s; }
.nb-work-card:hover .nb-work-overlay h3 { color:var(--accent); }
.nb-work-overlay p { font-size:12px; color:rgba(255,255,255,.5); letter-spacing:.12em; font-weight:700; }
.nb-works-viewall-mobile-wrap { display:flex; justify-content:center; margin-top:40px; padding:0 24px; }
.nb-works-viewall-mobile { display:flex; align-items:center; gap:8px; border:1px solid rgba(255,255,255,.15); border-radius:999px; padding:16px 32px; font-size:12px; font-weight:900; letter-spacing:.12em; transition:.2s; }
.nb-works-viewall-mobile:hover { border-color:rgba(245,160,0,.5); color:var(--accent); }

.nb-camp-card { height:600px; border-radius:64px; overflow:hidden; position:relative; box-shadow:0 25px 70px rgba(245,160,0,.1); }
.nb-camp-card img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; filter:brightness(.6); transition:1.2s ease; }
.nb-camp-card:hover img { transform:scale(1.07); }
.nb-camp-overlay { position:absolute; inset:0; background:linear-gradient(to right, rgba(0,0,0,.8), rgba(0,0,0,.2), transparent); }
.nb-camp-card > div { position:relative; z-index:2; padding:120px 90px; max-width:760px; }
.nb-camp-copy { max-width:560px; color:var(--muted); margin:0 0 34px; line-height:1.8; font-size:20px; font-weight:600; }

.nb-support-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.nb-support-card { background:#fff; border-radius:42px; padding:40px; position:relative; min-height:320px; box-shadow:0 8px 32px rgba(0,0,0,.08); }
.nb-support-card .num { position:absolute; right:24px; top:10px; font-size:74px; font-weight:900; color:rgba(0,0,0,.06); }
.nb-support-card h3 { margin-bottom:14px; font-size:28px; }
.nb-support-card p { color:#666; line-height:1.8; }
.nb-support-arrow { margin-top:20px; width:40px; height:40px; border-radius:999px; border:1px solid rgba(0,0,0,.1); display:flex; align-items:center; justify-content:center; font-size:24px; transition:.35s; position:relative; z-index:2; }
.nb-support-card { transition:.4s; }
.nb-support-card:hover { transform:translateY(-10px); background:#050505; box-shadow:0 32px 80px rgba(0,0,0,.18); }
.nb-support-card:hover .num { color:rgba(255,255,255,.05); }
.nb-support-card:hover h3 { color:#fff; }
.nb-support-card:hover p { color:var(--muted); }
.nb-support-card:hover .nb-support-arrow { border-color:rgba(255,255,255,.2); background:var(--accent); color:#000; }

.nb-news-wrap { max-width:980px; }
.nb-news-item { display:grid; grid-template-columns:130px 80px 1fr; gap:16px; align-items:center; padding:24px 8px; border-bottom:1px solid rgba(255,255,255,.08); }
.nb-news-item span { font-size:11px; letter-spacing:.12em; color:var(--muted); font-weight:900; }
.nb-news-item em { font-style:normal; font-size:10px; letter-spacing:.14em; background:rgba(255,255,255,.1); border-radius:999px; padding:6px 10px; text-align:center; }
.nb-news-item p { font-size:20px; font-weight:700; }
.nb-news-item strong { color:rgba(255,255,255,.2); font-size:20px; justify-self:end; transition:.25s; }
.nb-news-item:hover { background:rgba(255,255,255,.02); transform:translateX(6px); transition:.25s; }
.nb-news-item:hover em, .nb-news-item:hover p, .nb-news-item:hover strong { color:var(--accent); }
.nb-news-item:hover em { background:var(--accent); color:#000; }

.nb-cta { background:linear-gradient(130deg,var(--accent),var(--accent2)); color:#000; padding:160px 0; position:relative; overflow:hidden; }
.nb-cta::before { content:''; position:absolute; inset:0; opacity:.1; background-image:url('https://www.transparenttextures.com/patterns/carbon-fibre.png'); }
.nb-cta h2 { margin-bottom:26px; }
.nb-cta-copy { font-size:clamp(20px,2.5vw,32px); color:rgba(0,0,0,.7); font-weight:900; line-height:1.6; margin:0 0 48px; }
.nb-center { text-align:center; }
.nb-cta-actions { display:flex; justify-content:center; gap:16px; }
.nb-dark-btn, .nb-light-btn { border-radius:999px; padding:18px 28px; font-size:12px; letter-spacing:.16em; font-weight:900; }
.nb-dark-btn { background:#000; color:#fff; }
.nb-light-btn { background:#fff; color:#000; }

.nb-footer { border-top:1px solid rgba(255,255,255,.08); padding:110px 0 40px; }
.nb-footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr; gap:40px; }
.nb-footer h3 { color:var(--accent); font-size:40px; margin-bottom:16px; }
.nb-footer h4 { color:var(--muted); letter-spacing:.28em; font-size:11px; margin-bottom:16px; }
.nb-footer p, .nb-footer li a { color:var(--muted); line-height:1.8; }
.nb-footer ul { list-style:none; padding:0; margin:0; display:grid; gap:10px; }
.nb-footer-logo-row { display:flex; align-items:center; gap:10px; margin-bottom:24px; }
.nb-footer-divider { width:4px; height:34px; background:rgba(255,255,255,.2); margin:0 6px; }
.nb-footer-logo-row span { color:var(--muted); font-size:12px; letter-spacing:.16em; font-weight:700; text-transform:uppercase; line-height:1.4; }
.nb-footer-brand p { max-width:440px; margin-bottom:24px; }
.nb-footer-socials { display:flex; gap:12px; }
.nb-footer-socials a { width:40px; height:40px; border-radius:999px; border:1px solid rgba(255,255,255,.1); display:flex; align-items:center; justify-content:center; font-size:10px; font-weight:900; }
.nb-footer-socials a:hover { background:var(--accent); color:#000; border-color:var(--accent); }
.nb-footer-contact li { display:flex; flex-direction:column; gap:4px; }
.nb-footer-contact span { color:rgba(255,255,255,.4); font-size:10px; letter-spacing:.14em; }
.nb-footer-contact strong { color:#fff; font-size:14px; }
.nb-copy-row { margin-top:48px; padding-top:24px; border-top:1px solid rgba(255,255,255,.08); display:flex; align-items:center; justify-content:space-between; gap:20px; }
.nb-copy { color:rgba(255,255,255,.3); font-size:10px; letter-spacing:.18em; text-transform:uppercase; }
.nb-copy-links { display:flex; gap:30px; }
.nb-copy-links a { color:rgba(255,255,255,.3); font-size:10px; letter-spacing:.18em; text-transform:uppercase; }
.nb-copy-links a:hover { color:#fff; }

.nb-fixed-contact { position:fixed; right:24px; bottom:26px; z-index:70; width:82px; height:82px; border-radius:999px; background:var(--accent); color:#000; display:flex; align-items:center; justify-content:center; box-shadow:0 8px 36px rgba(245,160,0,.52); font-size:10px; font-weight:900; transition:.25s; }
.nb-fixed-contact::before { content:''; position:absolute; inset:0; border-radius:999px; background:var(--accent); filter:blur(10px); animation:fixedPulse 2.6s ease-in-out infinite; z-index:-1; }
.nb-fixed-contact:hover { transform:translateY(-6px) scale(1.08); }
.nb-fixed-contact .tip { opacity:0; position:absolute; bottom:95px; background:#050505; color:#fff; border:1px solid rgba(255,255,255,.12); border-radius:999px; padding:8px 14px; white-space:nowrap; font-size:11px; transition:.2s; }
.nb-fixed-contact:hover .tip { opacity:1; transform:translateY(-4px); }
.nb-fixed-contact .label { text-align:center; line-height:1.3; letter-spacing:.02em; font-size:8.5px; }

.fade-up { opacity:0; transform:translateY(44px); transition:opacity .95s, transform .95s; }
.fade-up.in-view { opacity:1; transform:translateY(0); }

@keyframes bounce { 0%,20%,50%,80%,100% { transform:translateY(0) translateX(-50%);} 40% { transform:translateY(-10px) translateX(-50%);} 60% { transform:translateY(-5px) translateX(-50%);} }
@keyframes ytPulse1 { 0% { transform:scale(1); opacity:.6; } 70% { transform:scale(1.55); opacity:0; } 100% { transform:scale(1); opacity:.6; } }
@keyframes ytPulse2 { 0% { transform:scale(1); opacity:.5; } 70% { transform:scale(1.4); opacity:0; } 100% { transform:scale(1); opacity:.5; } }
@keyframes fixedPulse { 0% { transform:scale(1); opacity:.45; } 70% { transform:scale(1.5); opacity:0; } 100% { transform:scale(1); opacity:.45; } }
.scroll-indicator { animation:bounce 2.4s ease-in-out infinite; }

::-webkit-scrollbar { width:8px; }
::-webkit-scrollbar-track { background:#050505; }
::-webkit-scrollbar-thumb { background:#222; border-radius:10px; }

@media (max-width: 1100px) {
  .nb-strength-grid { grid-template-columns:repeat(2,1fr); }
  .nb-support-grid { grid-template-columns:1fr; }
}
@media (max-width: 900px) {
  .nb-grid2, .nb-services-grid, .nb-footer-grid { grid-template-columns:1fr; }
  .nb-services-head { display:block; margin-bottom:56px; }
  .nb-services-lead { max-width:none; font-size:18px; margin-top:12px; }
  .nb-works-header { margin-bottom:56px; }
  .nb-works-viewall-desktop { display:none; }
  .nb-camp-copy { font-size:18px; }
  .nb-nav-links { display:none; position:absolute; top:100%; left:0; right:0; background:#050505; padding:18px 24px; border-top:1px solid rgba(255,255,255,.08); flex-direction:column; }
  .nb-nav-links.is-open { display:flex; }
  .nb-menu-btn { display:block; border:none; background:none; color:#fff; font-weight:900; letter-spacing:.1em; }
  .desktop-only { display:none !important; }
  .mobile-only { display:block; border:none; background:none; color:#fff; font-size:26px; padding:4px; }
  .nb-contact-btn { display:none; }
  .nb-hero-label { display:none; }
  .nb-cta-actions { flex-direction:column; align-items:center; }
  .nb-news-item { grid-template-columns:1fr; }
  .nb-camp-card > div { padding:64px 32px; }
  .nb-copy-row { flex-direction:column; align-items:flex-start; }
  .nb-copy-links { gap:18px; }
}
@media (min-width: 640px) {
  .hidden-sm { display:block; }
}
@media (min-width: 768px) {
  .hidden-md { display:none; }
  .nb-work-card { width:450px; }
  .nb-works-viewall-mobile-wrap { display:none; }
}

/* Company page */
.company-hero { position:relative; padding:176px 24px 128px; overflow:hidden; }
.company-hero-bg { position:absolute; inset:0; background:linear-gradient(to bottom right,#0d0800,#050505,#050505); }
.company-hero-inner { position:relative; z-index:2; max-width:960px; }
.company-back { display:inline-block; margin-bottom:40px; font-size:11px; letter-spacing:.2em; color:rgba(255,255,255,.35); font-weight:900; }
.company-back:hover { color:var(--accent); }
.company-hero h1 { font-size:clamp(52px,8vw,108px); letter-spacing:-.03em; margin:12px 0 18px; }
.company-hero p { color:rgba(255,255,255,.55); line-height:1.9; }
.company-anchors { margin-top:44px; display:flex; gap:10px; flex-wrap:wrap; }
.company-anchors a { font-size:11px; letter-spacing:.22em; border:1px solid rgba(255,255,255,.1); color:var(--muted); border-radius:999px; padding:10px 16px; font-weight:900; }
.company-anchors a:hover { color:var(--accent); border-color:rgba(245,160,0,.5); }

.company-message { background:#f7f7f7; color:#000; padding:128px 24px; }
.company-message-card { background:#fff; border:1px solid rgba(0,0,0,.06); border-radius:44px; box-shadow:0 8px 30px rgba(0,0,0,.07); padding:48px; }
.company-message-card .lead { font-size:clamp(24px,3vw,36px); font-weight:900; line-height:1.5; margin-bottom:20px; }
.company-message-card p { color:#444; line-height:1.95; margin-bottom:14px; }
.company-message-card .sign { margin-top:28px; color:#000; font-weight:900; font-size:24px; }

.company-profile { padding:128px 24px; background:#050505; }
.company-profile-grid { margin-top:24px; display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
.company-profile-item { border:1px solid rgba(255,255,255,.08); border-radius:32px; background:rgba(255,255,255,.03); padding:28px; }
.company-profile-item span { display:block; font-size:10px; letter-spacing:.2em; color:rgba(191,199,213,.7); font-weight:900; margin-bottom:8px; text-transform:uppercase; }
.company-profile-item p { font-weight:700; line-height:1.7; word-break:break-word; }

.company-access { background:#f7f7f7; color:#000; padding:128px 24px; }
.company-access .addr { color:#555; font-weight:700; margin-bottom:18px; }
.company-map { background:linear-gradient(to bottom right,#e8e8e8,#d0d0d0); border:1px solid rgba(0,0,0,.06); border-radius:48px; min-height:380px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:14px; box-shadow:0 20px 50px rgba(0,0,0,.12); }
.company-map .pin { font-size:44px; }
.company-map p { color:#555; font-size:12px; letter-spacing:.16em; font-weight:900; text-transform:uppercase; }

.company-staff { background:#050505; padding:128px 24px; }
.company-staff-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:24px; margin-top:20px; }
.company-person, .company-dog { background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.08); border-radius:36px; overflow:hidden; }
.company-person img { width:100%; height:260px; object-fit:cover; filter:brightness(.78); }
.company-dogs-grid { margin-top:30px; display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.company-dog img { width:100%; height:210px; object-fit:cover; filter:brightness(.75); }
.company-person .body, .company-dog .body { padding:24px; }
.company-person .body span, .company-dog .body span { display:block; font-size:10px; color:var(--accent); letter-spacing:.24em; font-weight:900; margin-bottom:8px; }
.company-person .body h3, .company-dog .body h3 { margin:0 0 4px; font-size:28px; letter-spacing:-.02em; }
.company-dog .body h3 { font-size:24px; }
.company-person .body .en, .company-dog .body .en { color:rgba(191,199,213,.55); font-size:11px; letter-spacing:.12em; margin-bottom:12px; font-weight:700; }
.company-person .body p, .company-dog .body p { color:var(--muted); line-height:1.8; }

.company-cta { background:#f7f7f7; color:#000; padding:128px 24px; text-align:center; }
.company-cta h2 { font-size:clamp(40px,6vw,74px); margin:12px 0 20px; }
.company-cta p { color:#555; font-size:20px; line-height:1.8; margin-bottom:36px; }
.company-cta .cta-actions { display:flex; justify-content:center; gap:14px; flex-wrap:wrap; }

@media (max-width: 900px) {
  .company-profile-grid, .company-staff-grid, .company-dogs-grid { grid-template-columns:1fr; }
  .company-message-card { padding:32px; border-radius:28px; }
  .company-map { min-height:280px; border-radius:32px; }
}

/* Service page */
.service-side-nav { position:fixed; right:24px; top:50%; transform:translateY(-50%); z-index:40; display:none; flex-direction:column; gap:14px; }
.service-side-nav a { display:flex; align-items:center; justify-content:flex-end; gap:10px; }
.service-side-nav a span { font-size:9px; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.0); transition:.25s; font-weight:900; }
.service-side-nav a i { width:8px; height:8px; border-radius:999px; background:rgba(255,255,255,.25); display:block; }
.service-side-nav a:hover span { color:rgba(255,255,255,.5); }
.service-side-nav a:hover i { background:var(--accent); transform:scale(1.5); }

.service-hero { position:relative; padding:176px 0 120px; overflow:hidden; }
.service-hero-bg, .service-hero-bg img { position:absolute; inset:0; width:100%; height:100%; }
.service-hero-bg img { object-fit:cover; filter:brightness(.12); transform:scale(1.05); }
.service-hero-bg::after { content:''; position:absolute; inset:0; background:linear-gradient(to bottom, rgba(5,5,5,.7), rgba(5,5,5,.45), #050505); }
.service-hero-inner { position:relative; z-index:2; }
.service-hero h1 { font-size:clamp(50px,8vw,106px); margin:12px 0 20px; letter-spacing:-.03em; }
.service-hero p { color:rgba(255,255,255,.5); line-height:1.9; font-size:clamp(16px,2vw,22px); }
.service-hero p strong { color:rgba(255,255,255,.8); }
.service-chip-row { margin-top:40px; display:flex; gap:12px; overflow:auto; padding-bottom:8px; }
.service-chip-row a { flex:0 0 auto; display:flex; align-items:center; gap:10px; padding:14px 16px; border:1px solid rgba(255,255,255,.12); border-radius:18px; }
.service-chip-row a:hover { border-color:rgba(245,160,0,.6); background:rgba(245,160,0,.06); }
.service-chip-row a b { color:rgba(245,160,0,.65); font-size:9px; letter-spacing:.14em; }
.service-chip-row a span { color:rgba(255,255,255,.84); font-size:12px; font-weight:900; letter-spacing:.08em; }
.service-scroll { margin-top:40px; text-align:center; color:rgba(255,255,255,.2); font-size:10px; letter-spacing:.3em; font-weight:900; }

.service-section { position:relative; overflow:hidden; background:#050505; scroll-margin-top:80px; }
.service-bg, .service-bg img { position:absolute; inset:0; width:100%; height:100%; }
.service-bg img { object-fit:cover; filter:brightness(.2); }
.service-bg::after { content:''; position:absolute; inset:0; background:rgba(5,5,5,.85); }
.service-grid { position:relative; z-index:2; display:grid; grid-template-columns:1fr 1fr; gap:60px; padding:120px 0; }
.service-copy h2 { color:#fff; font-size:clamp(34px,4.6vw,62px); line-height:1.14; margin:10px 0 16px; }
.service-headline { display:flex; align-items:center; gap:14px; margin-bottom:10px; }
.service-headline .icon { width:48px; height:48px; border-radius:16px; background:var(--accent); color:#000; display:flex; align-items:center; justify-content:center; font-weight:900; }
.service-headline .meta span { display:block; font-size:9px; letter-spacing:.35em; color:rgba(245,160,0,.6); font-weight:900; }
.service-headline .meta strong { display:block; font-size:11px; letter-spacing:.26em; color:var(--accent); text-transform:uppercase; }
.service-copy .lead { color:rgba(255,255,255,.82); border-left:2px solid var(--accent); padding-left:14px; font-size:18px; line-height:1.8; font-weight:700; margin-bottom:14px; }
.service-copy .body { color:var(--muted); line-height:1.95; margin-bottom:10px; font-size:15px; }
.service-copy .points { margin-top:20px; display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.service-copy .points div { background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.1); border-radius:12px; padding:12px; color:rgba(255,255,255,.86); font-size:12px; font-weight:700; }
.service-copy .points div:hover { border-color:rgba(245,160,0,.45); background:rgba(255,255,255,.05); transform:translateX(4px); transition:.2s; }

.service-images .main { position:relative; border-radius:32px; overflow:hidden; aspect-ratio:4/3; box-shadow:0 24px 60px rgba(0,0,0,.5); margin-bottom:14px; }
.service-images .main img { width:100%; height:100%; object-fit:cover; filter:brightness(.78); transition:.7s; }
.service-images .main:hover img { transform:scale(1.04); filter:brightness(.9); }
.service-images .main span { position:absolute; left:18px; bottom:18px; background:var(--accent); color:#000; border-radius:999px; font-size:10px; letter-spacing:.14em; font-weight:900; padding:6px 12px; }
.service-images .sub { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.service-images .sub img { width:100%; aspect-ratio:1/1; object-fit:cover; border-radius:24px; filter:brightness(.72); box-shadow:0 12px 40px rgba(0,0,0,.4); transition:.6s; }
.service-images .sub img:hover { transform:scale(1.06); filter:brightness(.84); }

.service-section.is-odd .service-grid .order-1 { order:1; }
.service-section.is-odd .service-grid .order-2 { order:2; }

.service-statement { padding:96px 24px; background:#050505; }
.service-statement blockquote { font-size:clamp(28px,4.4vw,52px); line-height:1.5; letter-spacing:-.02em; font-weight:900; color:rgba(255,255,255,.86); }
.service-statement blockquote span { color:var(--accent); }
.service-statement p { margin-top:20px; color:rgba(255,255,255,.28); font-size:10px; letter-spacing:.3em; font-weight:900; text-transform:uppercase; }

.service-cta { position:relative; overflow:hidden; padding:150px 24px; text-align:center; }
.service-cta-bg, .service-cta-bg img { position:absolute; inset:0; width:100%; height:100%; }
.service-cta-bg img { object-fit:cover; filter:brightness(.2); }
.service-cta-bg::after { content:''; position:absolute; inset:0; background:linear-gradient(135deg, rgba(5,5,5,.85), rgba(5,5,5,.65), rgba(5,5,5,.85)); }
.service-cta .nb-container { position:relative; z-index:2; }
.service-cta h2 { color:#fff; font-size:clamp(42px,6vw,84px); line-height:1.1; margin:12px 0 20px; }
.service-cta h2 span { background:linear-gradient(to right,var(--accent),var(--accent2)); -webkit-background-clip:text; color:transparent; }
.service-cta p { color:rgba(255,255,255,.52); font-size:18px; line-height:1.9; margin-bottom:36px; }

@media (min-width: 1280px) {
  .service-side-nav { display:flex; }
}
@media (max-width: 960px) {
  .service-grid { grid-template-columns:1fr; gap:32px; padding:96px 0; }
  .service-copy .points { grid-template-columns:1fr; }
  .service-section.is-odd .service-grid .order-1,
  .service-section.is-odd .service-grid .order-2 { order:initial; }
}

/* Opening support page */
.support-hero { position:relative; padding:160px 24px 110px; overflow:hidden; }
.support-hero-bg { position:absolute; inset:0; background:linear-gradient(to bottom right,#0d0800,#050505,#050505); }
.support-hero-bg::after { content:''; position:absolute; top:0; left:50%; transform:translateX(-50%); width:800px; height:400px; border-radius:999px; background:rgba(245,160,0,.06); filter:blur(120px); }
.support-hero-inner { position:relative; z-index:2; max-width:980px; }
.support-hero h1 { font-size:clamp(48px,7vw,88px); margin:12px 0 18px; line-height:1.08; letter-spacing:-.03em; }
.support-hero h1 span { background:linear-gradient(to right,var(--accent),var(--accent2)); -webkit-background-clip:text; color:transparent; }
.support-hero p { color:var(--muted); font-size:18px; line-height:1.8; max-width:860px; }
.support-hero-btns { margin-top:34px; display:flex; gap:12px; flex-wrap:wrap; }
.support-hero-btns a { border:1px solid rgba(255,255,255,.12); background:rgba(255,255,255,.05); border-radius:999px; padding:12px 18px; font-size:11px; letter-spacing:.16em; font-weight:900; }
.support-hero-btns a:hover { border-color:rgba(245,160,0,.45); box-shadow:0 0 24px rgba(245,160,0,.3); }

.support-subsidy { background:#f7f7f7; color:#000; padding:128px 24px; }
.support-head { margin-bottom:68px; }
.support-head p { color:#555; font-size:19px; line-height:1.8; max-width:860px; font-weight:600; }
.support-subsidy-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; margin-bottom:56px; }
.support-subsidy-card { background:#fff; border:1px solid rgba(0,0,0,.05); border-radius:32px; padding:34px; transition:.3s; }
.support-subsidy-card:hover { transform:translateY(-6px); box-shadow:0 24px 60px rgba(0,0,0,.1); border-color:rgba(245,160,0,.3); }
.support-subsidy-card .title-row { display:flex; justify-content:space-between; align-items:flex-start; gap:12px; margin-bottom:14px; }
.support-subsidy-card h3 { font-size:24px; line-height:1.3; }
.support-subsidy-card span { background:rgba(245,160,0,.1); color:var(--accent); border-radius:999px; padding:6px 10px; font-size:10px; letter-spacing:.12em; font-weight:900; }
.support-subsidy-card p { color:#666; line-height:1.8; font-size:14px; }

.support-dark-cta { background:#050505; border-radius:40px; padding:44px; display:flex; align-items:center; justify-content:space-between; gap:20px; }
.support-dark-cta span { color:var(--accent); font-size:11px; letter-spacing:.3em; font-weight:900; display:block; margin-bottom:8px; }
.support-dark-cta p { color:#fff; font-size:34px; line-height:1.25; letter-spacing:-.02em; font-weight:900; }
.support-dark-cta a { background:var(--accent); color:#000; border-radius:999px; padding:18px 28px; font-size:12px; letter-spacing:.16em; font-weight:900; box-shadow:0 0 30px rgba(245,160,0,.3); white-space:nowrap; }

.support-health { background:#050505; color:#fff; padding:128px 24px; }
.support-health .support-head p { color:var(--muted); }
.support-timeline { position:relative; }
.support-timeline::before { content:''; position:absolute; left:50%; top:0; bottom:0; width:1px; background:linear-gradient(to bottom, rgba(245,160,0,.4), rgba(255,255,255,.1), transparent); display:none; }
.support-step { display:grid; grid-template-columns:1fr 56px 1fr; gap:24px; align-items:center; margin-bottom:28px; }
.support-step article { background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); border-radius:30px; padding:30px; transition:.3s; }
.support-step article:hover { border-color:rgba(245,160,0,.25); transform:translateY(-4px); }
.support-step article span { color:var(--accent); font-size:12px; letter-spacing:.3em; font-weight:900; display:block; margin-bottom:10px; }
.support-step article h3 { font-size:24px; margin-bottom:10px; line-height:1.3; }
.support-step article p { color:var(--muted); line-height:1.8; font-size:14px; }
.support-step .dot { width:56px; height:56px; border-radius:999px; background:var(--accent); color:#000; display:flex; align-items:center; justify-content:center; font-size:22px; font-weight:900; box-shadow:0 0 30px rgba(245,160,0,.4); }

.support-points { margin-top:72px; background:linear-gradient(to bottom right, rgba(245,160,0,.1), transparent); border:1px solid rgba(245,160,0,.2); border-radius:40px; padding:40px; }
.support-points h3 { font-size:38px; letter-spacing:-.02em; margin-bottom:24px; }
.support-points .grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.support-points .grid b { display:block; margin-bottom:8px; font-size:17px; }
.support-points .grid p { color:var(--muted); line-height:1.7; font-size:14px; }

.support-contact { background:#f7f7f7; color:#000; padding:128px 24px; text-align:center; }
.support-contact h2 { font-size:clamp(42px,6vw,74px); margin:10px 0 18px; }
.support-contact p { color:#555; font-size:20px; line-height:1.8; margin-bottom:34px; }
.nb-secondary-link.dark { color:#333; border-bottom-color:rgba(0,0,0,.1); }
.nb-secondary-link.dark:hover { color:var(--accent); border-bottom-color:var(--accent); }

@media (min-width: 900px) {
  .support-timeline::before { display:block; }
}
@media (max-width: 960px) {
  .support-subsidy-grid { grid-template-columns:1fr; }
  .support-dark-cta { flex-direction:column; align-items:flex-start; }
  .support-dark-cta p { font-size:28px; }
  .support-step { grid-template-columns:1fr; }
  .support-step .spacer { display:none; }
  .support-step .dot { margin:0 auto; }
  .support-points .grid { grid-template-columns:1fr; }
}

/* Why/Reason page */
.reason-hero { position:relative; padding:176px 24px 120px; overflow:hidden; }
.reason-hero-bg, .reason-hero-bg img { position:absolute; inset:0; width:100%; height:100%; }
.reason-hero-bg img { object-fit:cover; filter:brightness(.12); transform:scale(1.05); }
.reason-hero-bg::after { content:''; position:absolute; inset:0; background:linear-gradient(to bottom, rgba(5,5,5,.6), rgba(5,5,5,.3), #050505); }
.reason-hero-inner { position:relative; z-index:2; }
.reason-hero h1 { font-size:clamp(52px,8vw,108px); line-height:1.05; margin:12px 0 20px; letter-spacing:-.03em; }
.reason-hero p { color:rgba(255,255,255,.48); font-size:clamp(16px,2vw,22px); line-height:1.85; }
.reason-hero p strong { color:rgba(255,255,255,.75); }
.reason-keywords { margin-top:34px; display:flex; flex-wrap:wrap; gap:10px; }
.reason-keywords span { border:1px solid rgba(255,255,255,.12); border-radius:999px; padding:9px 14px; color:var(--muted); font-size:11px; letter-spacing:.12em; font-weight:900; }

.reason-section { position:relative; background:#050505; overflow:hidden; }
.reason-bg, .reason-bg img { position:absolute; inset:0; width:100%; height:100%; }
.reason-bg img { object-fit:cover; filter:brightness(.18); }
.reason-bg::after { content:''; position:absolute; inset:0; background:rgba(5,5,5,.88); }
.reason-grid { position:relative; z-index:2; display:grid; grid-template-columns:1fr 1fr; gap:70px; padding:118px 0; }
.reason-copy .num { font-size:clamp(90px,10vw,170px); color:rgba(255,255,255,.06); font-weight:900; letter-spacing:-.04em; line-height:.9; margin-bottom:4px; }
.reason-copy .reason-head span { color:var(--accent); font-size:11px; letter-spacing:.32em; font-weight:900; text-transform:uppercase; display:block; margin-bottom:14px; }
.reason-copy h2 { color:#fff; font-size:clamp(34px,4.4vw,62px); line-height:1.15; margin:0 0 18px; }
.reason-copy p { color:#d4d9e2; font-size:16px; line-height:1.95; margin-bottom:10px; }
.reason-points { display:flex; flex-direction:column; gap:10px; justify-content:center; }
.reason-points div { border:1px solid rgba(255,255,255,.1); background:rgba(255,255,255,.03); border-radius:16px; padding:18px; font-size:16px; font-weight:700; }
.reason-points div:hover { border-color:rgba(245,160,0,.5); background:rgba(255,255,255,.05); box-shadow:0 8px 32px rgba(245,160,0,.1); transform:translateX(6px); transition:.2s; }
.reason-points small { color:rgba(255,255,255,.2); font-size:10px; letter-spacing:.3em; font-weight:900; margin-top:12px; text-transform:uppercase; }
.reason-section.is-odd .reason-grid .order-1 { order:1; }
.reason-section.is-odd .reason-grid .order-2 { order:2; }

.reason-statement { background:#050505; padding:96px 24px; position:relative; overflow:hidden; }
.reason-statement::before { content:''; position:absolute; inset:0; background-image:url('https://www.transparenttextures.com/patterns/carbon-fibre.png'); opacity:.04; }
.reason-statement::after { content:''; position:absolute; left:0; top:0; bottom:0; width:1px; background:linear-gradient(to bottom, transparent, var(--accent), transparent); }
.reason-statement .nb-container { position:relative; z-index:2; }
.reason-statement blockquote { font-size:clamp(34px,5vw,70px); line-height:1.28; font-weight:900; letter-spacing:-.02em; color:rgba(255,255,255,.9); }
.reason-statement blockquote span { color:var(--accent); }
.reason-statement p { margin-top:24px; color:rgba(255,255,255,.3); font-size:11px; letter-spacing:.3em; font-weight:900; text-transform:uppercase; }

.reason-flow { background:#f7f7f7; color:#000; padding:112px 24px; }
.reason-flow-head { text-align:center; margin-bottom:64px; }
.reason-flow-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:0; position:relative; }
.reason-flow-grid::before { content:''; position:absolute; top:40px; left:10%; right:10%; height:1px; background:linear-gradient(to right, transparent, rgba(245,160,0,.3), transparent); }
.reason-flow-grid article { text-align:center; padding:24px 14px; position:relative; z-index:2; }
.reason-flow-grid .bubble { width:80px; height:80px; border-radius:999px; background:var(--accent); box-shadow:0 0 20px rgba(245,160,0,.25); margin:0 auto 16px; display:flex; flex-direction:column; align-items:center; justify-content:center; }
.reason-flow-grid .bubble span { font-size:9px; letter-spacing:.1em; color:rgba(0,0,0,.6); font-weight:900; }
.reason-flow-grid .bubble b { font-size:24px; line-height:1; }
.reason-flow-grid h3 { font-size:17px; margin-bottom:8px; }
.reason-flow-grid p { color:#555; font-size:13px; line-height:1.7; }

.reason-cta { position:relative; overflow:hidden; padding:148px 24px; text-align:center; }
.reason-cta-bg, .reason-cta-bg img { position:absolute; inset:0; width:100%; height:100%; }
.reason-cta-bg img { object-fit:cover; filter:brightness(.25); }
.reason-cta-bg::after { content:''; position:absolute; inset:0; background:linear-gradient(135deg, rgba(5,5,5,.8), rgba(5,5,5,.6), rgba(5,5,5,.8)); }
.reason-cta::before { content:''; position:absolute; inset:0; background:linear-gradient(to bottom right, rgba(245,160,0,.15), transparent); animation:reasonGlow 4s ease-in-out infinite; }
.reason-cta .nb-container { position:relative; z-index:2; }
.reason-cta h2 { color:#fff; font-size:clamp(40px,6vw,82px); line-height:1.08; margin:12px 0 18px; }
.reason-cta h2 span { background:linear-gradient(to right,var(--accent),var(--accent2)); -webkit-background-clip:text; color:transparent; }
.reason-cta p { color:rgba(255,255,255,.52); font-size:19px; line-height:1.9; margin-bottom:38px; }

@keyframes reasonGlow { 0% { opacity:.6; } 50% { opacity:1; } 100% { opacity:.6; } }
@media (max-width: 1100px) {
  .reason-grid { grid-template-columns:1fr; gap:28px; }
  .reason-section.is-odd .reason-grid .order-1,
  .reason-section.is-odd .reason-grid .order-2 { order:initial; }
  .reason-flow-grid { grid-template-columns:1fr; gap:16px; }
  .reason-flow-grid::before { display:none; }
}

/* Works page */
.works-page { background:#fff; color:#000; }
.works-hero { position:relative; padding:176px 24px 96px; color:#fff; background:#050505; overflow:hidden; }
.works-hero-bg, .works-hero-bg img { position:absolute; inset:0; width:100%; height:100%; }
.works-hero-bg img { object-fit:cover; filter:brightness(.1); transform:scale(1.05); }
.works-hero-bg::after { content:''; position:absolute; inset:0; background:linear-gradient(to bottom, rgba(5,5,5,.7), transparent, #050505); }
.works-hero-inner { position:relative; z-index:2; }
.works-hero h1 { font-size:clamp(52px,8vw,108px); line-height:1.05; margin:10px 0 16px; letter-spacing:-.03em; }
.works-hero p { color:rgba(255,255,255,.5); line-height:1.85; }
.works-stats { margin-top:38px; display:flex; gap:24px; flex-wrap:wrap; }
.works-stats b { display:block; color:var(--accent); font-size:42px; line-height:1; letter-spacing:-.02em; }
.works-stats span { font-size:10px; letter-spacing:.28em; color:rgba(255,255,255,.3); text-transform:uppercase; font-weight:900; }

.works-filter { position:sticky; top:64px; z-index:30; background:rgba(255,255,255,.95); backdrop-filter:blur(12px); border-bottom:1px solid rgba(0,0,0,.08); }
.works-filter-row { display:flex; gap:10px; align-items:center; overflow:auto; padding:16px 0; }
.works-filter-row span { flex:0 0 auto; font-size:10px; letter-spacing:.2em; color:rgba(0,0,0,.3); font-weight:900; border-right:1px solid rgba(0,0,0,.08); padding-right:12px; margin-right:6px; }
.works-filter-row button { flex:0 0 auto; border:1px solid rgba(0,0,0,.12); border-radius:999px; padding:9px 14px; background:#fff; color:rgba(0,0,0,.45); font-size:11px; letter-spacing:.18em; font-weight:900; }
.works-filter-row button em { margin-left:6px; width:16px; height:16px; border-radius:999px; font-style:normal; background:rgba(0,0,0,.07); display:inline-flex; align-items:center; justify-content:center; font-size:9px; }
.works-filter-row button.is-active { background:var(--accent); border-color:var(--accent); color:#000; box-shadow:0 0 14px rgba(245,160,0,.35); }

.works-list-wrap { border-top:1px solid rgba(0,0,0,.08); }
.work-row { border-bottom:1px solid rgba(0,0,0,.08); }
.row-grid { display:grid; grid-template-columns:1fr 1fr; }
.row-grid.is-reverse .work-images { order:2; border-left:1px solid rgba(0,0,0,.08); border-right:0; }
.row-grid.is-reverse .work-copy { order:1; }
.work-images { border-right:1px solid rgba(0,0,0,.08); }
.work-images .main { position:relative; overflow:hidden; aspect-ratio:4/3; }
.work-images .main img { width:100%; height:100%; object-fit:cover; transition:.8s; }
.work-images .main:hover img { transform:scale(1.04); }
.work-images .main::after { content:''; position:absolute; inset:0; background:linear-gradient(to top, rgba(0,0,0,.2), transparent); }
.work-images .main .tags { position:absolute; top:20px; left:20px; display:flex; gap:8px; z-index:2; }
.work-images .main .tags .a { background:var(--accent); color:#000; border-radius:999px; padding:6px 10px; font-size:10px; font-weight:900; letter-spacing:.12em; }
.work-images .main .tags .b { background:rgba(255,255,255,.9); border:1px solid rgba(0,0,0,.1); border-radius:999px; padding:6px 10px; font-size:10px; font-weight:900; letter-spacing:.12em; }
.work-images .subs { display:grid; grid-template-columns:1fr 1fr; border-top:1px solid rgba(0,0,0,.08); }
.work-images .subs img { width:100%; aspect-ratio:1/1; object-fit:cover; }
.work-images .subs img:first-child { border-right:1px solid rgba(0,0,0,.08); }

.work-copy { padding:56px 48px; background:#fff; }
.work-copy .num { display:block; color:rgba(0,0,0,.06); font-size:64px; font-weight:900; line-height:1; margin-bottom:6px; }
.work-copy h2 { color:#000; font-size:42px; letter-spacing:-.02em; margin:0 0 4px; }
.work-copy .client { color:rgba(0,0,0,.3); font-size:12px; letter-spacing:.12em; font-weight:700; margin-bottom:18px; }
.work-copy .desc { color:#444; line-height:1.85; margin-bottom:18px; }
.work-copy .specs { background:#f8f8f8; border:1px solid rgba(0,0,0,.06); border-radius:16px; padding:16px; margin-bottom:16px; }
.work-copy .specs div { display:flex; gap:12px; margin-bottom:8px; }
.work-copy .specs div:last-child { margin-bottom:0; }
.work-copy .specs label { width:72px; color:rgba(0,0,0,.35); font-size:10px; letter-spacing:.1em; font-weight:900; }
.work-copy .specs span { color:rgba(0,0,0,.75); font-size:14px; font-weight:700; }
.work-copy .features { display:flex; flex-wrap:wrap; gap:8px; }
.work-copy .features span { border:1px solid rgba(245,160,0,.3); background:rgba(245,160,0,.05); color:var(--accent); border-radius:999px; padding:6px 10px; font-size:10px; font-weight:900; letter-spacing:.1em; }

.works-empty { text-align:center; padding:120px 20px; }
.works-empty p { font-size:30px; color:rgba(0,0,0,.2); font-weight:900; margin-bottom:16px; }
.works-empty button { color:var(--accent); font-size:13px; font-weight:900; border:none; background:none; border-bottom:1px solid rgba(245,160,0,.4); padding-bottom:2px; }

.works-cta { background:#050505; color:#fff; text-align:center; padding:120px 24px; }
.works-cta h2 { color:#fff; margin:12px 0 18px; font-size:clamp(42px,6vw,76px); }
.works-cta p { color:rgba(255,255,255,.46); font-size:20px; line-height:1.8; margin-bottom:30px; }

@media (max-width: 980px) {
  .row-grid { grid-template-columns:1fr; }
  .row-grid.is-reverse .work-images { order:1; border-left:0; border-right:0; }
  .row-grid.is-reverse .work-copy { order:2; }
  .work-images { border-right:0; }
  .work-copy { padding:36px 24px; }
  .work-copy h2 { font-size:34px; }
}
