/* ============================================
   株式会社燈 — TOMOSHIBI Design System v2
   3D + AI Tech + Orange ともしび
   ============================================ */

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

:root{
  --bg:#050508;
  --bg2:#0a0a10;
  --bg3:#10101a;
  --bg4:#16162a;
  --w:#f0ece4;
  --o:#E8842A;
  --o2:#F2A54A;
  --o3:#FFD4A0;
  --o-dim:#C06A1A;
  --o-glow:rgba(232,132,42,.3);
  --o-glow2:rgba(232,132,42,.08);
  --mu:#4a4a5a;
  --li:#8888a0;
  --text:#a0a0b8;
  --border:rgba(232,132,42,.06);
  --border-h:rgba(232,132,42,.2);
  --glass:rgba(16,16,26,.6);
  --glass-border:rgba(232,132,42,.1);
}

html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--w);font-family:'Noto Sans JP','Hiragino Kaku Gothic ProN',sans-serif;font-weight:300;overflow-x:hidden;cursor:none}

::selection{background:var(--o);color:#000}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--o-dim);border-radius:2px}

a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ============= CURSOR ============= */
#cursor-glow{
  position:fixed;width:350px;height:350px;
  background:radial-gradient(circle,rgba(232,132,42,.08) 0%,rgba(232,132,42,.02) 30%,transparent 55%);
  border-radius:50%;pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);mix-blend-mode:screen;
  transition:width .3s,height .3s;
}
#cursor-dot{
  position:fixed;pointer-events:none;z-index:10000;
  transform:translate(-50%,-50%);
  font-size:22px;
  filter:drop-shadow(0 0 8px rgba(232,132,42,.7)) drop-shadow(0 0 24px rgba(232,132,42,.3));
  transition:transform .1s,font-size .2s,filter .2s;
  line-height:1;
}

/* ============= EMBERS ============= */
.embers{position:fixed;inset:0;pointer-events:none;z-index:1;overflow:hidden}
.ember{
  position:absolute;width:2px;height:2px;
  background:var(--o);border-radius:50%;opacity:0;
  animation:emberFloat linear infinite;
  box-shadow:0 0 4px rgba(232,132,42,.5);
}
@keyframes emberFloat{
  0%{opacity:0;transform:translateY(100vh) scale(.5)}
  10%{opacity:.5}90%{opacity:.2}
  100%{opacity:0;transform:translateY(-10vh) translateX(var(--drift,20px)) scale(0)}
}

/* ============= 3D CANVAS ============= */
#hero-3d{position:absolute;inset:0;z-index:0}
#hero-3d canvas{display:block;width:100%!important;height:100%!important}

/* ============= NAV ============= */
nav{
  position:fixed;top:0;left:0;right:0;z-index:500;
  display:flex;justify-content:space-between;align-items:center;
  padding:20px 48px;transition:all .4s;
}
nav.scrolled{
  background:rgba(5,5,8,.85);backdrop-filter:blur(20px) saturate(1.2);
  border-bottom:1px solid var(--glass-border);padding:16px 48px;
}
.logo{
  font-family:'Syne',sans-serif;font-weight:800;font-size:26px;
  color:var(--o);letter-spacing:-.02em;
  text-shadow:0 0 20px rgba(232,132,42,.4);transition:text-shadow .3s;
}
.logo:hover{text-shadow:0 0 40px rgba(232,132,42,.6)}
.logo i{font-style:normal;color:rgba(255,255,255,.1)}

.nav-links{display:flex;gap:36px;list-style:none;align-items:center}
.nav-links a{
  font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.12em;
  color:var(--mu);transition:all .3s;text-transform:uppercase;
}
.nav-links a:hover,.nav-links a.active{color:var(--o);text-shadow:0 0 12px rgba(232,132,42,.3)}
.nav-cta{
  font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.08em;
  padding:10px 28px;background:transparent;color:var(--o);font-weight:700;
  border:1px solid rgba(232,132,42,.3);cursor:pointer;transition:all .3s;
  position:relative;overflow:hidden;backdrop-filter:blur(10px);
}
.nav-cta::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(232,132,42,.1),transparent);
  opacity:0;transition:opacity .3s;
}
.nav-cta:hover::before{opacity:1}
.nav-cta:hover{border-color:var(--o);box-shadow:0 0 25px rgba(232,132,42,.15),inset 0 0 25px rgba(232,132,42,.05)}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;z-index:601;padding:8px}
.hamburger span{display:block;width:24px;height:2px;background:var(--w);transition:all .3s}
.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

.mobile-menu{
  display:none;position:fixed;inset:0;background:rgba(5,5,8,.98);z-index:600;
  flex-direction:column;justify-content:center;align-items:center;gap:28px;
  opacity:0;pointer-events:none;transition:opacity .3s;
}
.mobile-menu.open{opacity:1;pointer-events:all}
.mobile-menu a{font-family:'Syne',sans-serif;font-size:24px;font-weight:700;color:var(--w);transition:color .3s}
.mobile-menu a:hover{color:var(--o)}

/* ============= HERO ============= */
.hero{
  min-height:100vh;display:flex;flex-direction:column;justify-content:center;
  padding:140px 48px 100px;position:relative;overflow:hidden;
}

.hero-tag{
  font-family:'Space Mono',monospace;font-size:12px;color:var(--o);
  letter-spacing:.25em;margin-bottom:40px;
  display:flex;align-items:center;gap:14px;
  position:relative;z-index:2;
  opacity:0;animation:fadeUp .8s ease .3s forwards;
}
.hero-tag::before{content:'';width:40px;height:1px;background:var(--o);box-shadow:0 0 10px rgba(232,132,42,.5)}

.hero-title{
  font-family:'Syne',sans-serif;font-size:clamp(48px,8vw,110px);font-weight:800;
  line-height:.95;letter-spacing:-.04em;position:relative;z-index:2;
  opacity:0;animation:fadeUp .8s ease .5s forwards;
}
.hero-title .orange{
  color:var(--o);
  text-shadow:0 0 60px rgba(232,132,42,.3),0 0 120px rgba(232,132,42,.1);
}
.hero-title .dim{color:rgba(255,255,255,.08)}

.hero-sub{
  font-size:16px;color:var(--text);line-height:2.2;margin-top:36px;max-width:560px;
  position:relative;z-index:2;opacity:0;animation:fadeUp .8s ease .7s forwards;
}
.hero-ctas{
  margin-top:48px;display:flex;gap:16px;position:relative;z-index:2;
  opacity:0;animation:fadeUp .8s ease .9s forwards;
}

@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}

/* ============= GLASS CARDS ============= */
.glass-card{
  background:var(--glass);
  backdrop-filter:blur(20px) saturate(1.3);
  border:1px solid var(--glass-border);
  padding:44px 36px;position:relative;overflow:hidden;
  transition:all .5s cubic-bezier(.16,1,.3,1);
  transform-style:preserve-3d;
  transform:perspective(800px) rotateX(0) rotateY(0);
}
.glass-card::before{
  content:'';position:absolute;top:0;left:0;width:0;height:2px;
  background:linear-gradient(90deg,var(--o),var(--o2));
  transition:width .6s cubic-bezier(.16,1,.3,1);
  box-shadow:0 0 15px rgba(232,132,42,.4);
}
.glass-card:hover::before{width:100%}
/* Holographic shimmer */
.glass-card::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,
    rgba(232,132,42,.03) 0%,transparent 40%,
    rgba(232,132,42,.02) 60%,transparent 100%
  );
  opacity:0;transition:opacity .4s;pointer-events:none;
}
.glass-card:hover::after{opacity:1}
.glass-card:hover{
  border-color:var(--border-h);
  box-shadow:0 8px 40px rgba(232,132,42,.08),0 0 0 1px rgba(232,132,42,.05);
  transform:perspective(800px) translateY(-4px);
}

/* Scan line on card */
.glass-card .scan-line{
  position:absolute;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(232,132,42,.15),transparent);
  animation:cardScan 4s ease-in-out infinite;
  pointer-events:none;opacity:0;
}
.glass-card:hover .scan-line{opacity:1}
@keyframes cardScan{0%{top:0}100%{top:100%}}

/* ============= MARQUEE ============= */
.mq-wrap{
  overflow:hidden;padding:14px 0;
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  background:rgba(232,132,42,.015);
}
.mq-track{display:flex;animation:mq 35s linear infinite;width:max-content}
@keyframes mq{to{transform:translateX(-50%)}}
.mq-item{
  font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--mu);padding:0 36px;white-space:nowrap;
}
.mq-item .dot{color:var(--o);margin-right:10px}

/* ============= SECTION UTILS ============= */
.section-pad{padding:120px 48px}
.section-pad-sm{padding:80px 48px}
.sl{
  font-family:'Space Mono',monospace;font-size:10px;letter-spacing:.25em;
  text-transform:uppercase;color:var(--o);margin-bottom:48px;
  display:flex;align-items:center;gap:16px;
}
.sl::before{content:'';width:40px;height:1px;background:var(--o);box-shadow:0 0 8px rgba(232,132,42,.4)}
.section-title{
  font-family:'Syne',sans-serif;font-size:clamp(32px,4vw,56px);font-weight:800;
  letter-spacing:-.03em;line-height:1.1;margin-bottom:20px;
}
.section-title .orange{color:var(--o);text-shadow:0 0 30px rgba(232,132,42,.15)}
.section-title .dim{color:var(--mu)}
.section-sub{font-size:15px;color:var(--text);line-height:2;max-width:640px;margin-bottom:56px}
.bg-alt{background:var(--bg2)}

/* ============= GLOW DIVIDER ============= */
.glow-divider{
  height:1px;position:relative;
  background:linear-gradient(90deg,transparent 5%,var(--border) 50%,transparent 95%);
}
.glow-divider::after{
  content:'';position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:200px;height:30px;
  background:radial-gradient(ellipse,rgba(232,132,42,.2) 0%,transparent 70%);
}

/* ============= BUTTONS ============= */
.btn-primary{
  display:inline-flex;align-items:center;gap:12px;
  font-family:'Space Mono',monospace;font-size:12px;letter-spacing:.06em;
  padding:16px 36px;background:var(--o);color:#000;font-weight:700;
  transition:all .3s;position:relative;overflow:hidden;border:none;cursor:pointer;
}
.btn-primary::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);
  transform:translateX(-100%);transition:transform .6s;
}
.btn-primary:hover::after{transform:translateX(100%)}
.btn-primary:hover{background:var(--o2);gap:18px;box-shadow:0 0 40px rgba(232,132,42,.3),0 4px 20px rgba(232,132,42,.2)}

.btn-secondary{
  display:inline-flex;align-items:center;gap:12px;
  font-family:'Space Mono',monospace;font-size:12px;letter-spacing:.06em;
  padding:16px 36px;border:1px solid rgba(232,132,42,.2);color:var(--o);
  transition:all .3s;background:rgba(232,132,42,.03);cursor:pointer;
  backdrop-filter:blur(10px);
}
.btn-secondary:hover{border-color:var(--o);background:rgba(232,132,42,.08);gap:18px;
  box-shadow:0 0 25px rgba(232,132,42,.1),inset 0 0 20px rgba(232,132,42,.03)}

.btn-text{
  font-family:'Space Mono',monospace;font-size:12px;letter-spacing:.06em;
  color:var(--o);display:inline-flex;align-items:center;gap:8px;transition:gap .3s;
}
.btn-text:hover{gap:14px}

/* ============= SERVICE GRID ============= */
.srv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.srv-card{
  background:var(--glass);backdrop-filter:blur(16px);
  padding:48px 36px;position:relative;overflow:hidden;
  border:1px solid var(--glass-border);transition:all .5s;cursor:default;
  transform-style:preserve-3d;
}
.srv-card::before{
  content:'';position:absolute;top:0;left:0;width:0;height:2px;
  background:linear-gradient(90deg,var(--o),var(--o2));
  transition:width .6s cubic-bezier(.16,1,.3,1);
  box-shadow:0 0 12px rgba(232,132,42,.4);
}
.srv-card:hover::before{width:100%}
.srv-card:hover{
  border-color:var(--border-h);
  box-shadow:0 8px 40px rgba(232,132,42,.08),0 0 80px rgba(232,132,42,.03);
}
.srv-icon{font-size:36px;margin-bottom:24px;display:block;filter:drop-shadow(0 0 8px rgba(232,132,42,.3))}
.srv-num{font-family:'Space Mono',monospace;font-size:10px;letter-spacing:.2em;color:var(--o);margin-bottom:28px;opacity:.4}
.srv-name{font-family:'Syne',sans-serif;font-size:22px;font-weight:700;line-height:1.3;margin-bottom:16px}
.srv-body{font-size:13px;color:var(--text);line-height:2}
.srv-div{width:32px;height:1px;background:rgba(232,132,42,.15);margin:24px 0}
.srv-tags{display:flex;flex-wrap:wrap;gap:6px}
.srv-tag{
  font-family:'Space Mono',monospace;font-size:9px;letter-spacing:.06em;
  text-transform:uppercase;border:1px solid rgba(232,132,42,.1);
  padding:4px 12px;color:var(--o);opacity:.4;transition:all .3s;
  backdrop-filter:blur(4px);
}
.srv-card:hover .srv-tag{opacity:.7;border-color:rgba(232,132,42,.2)}

/* ============= WORKS ============= */
.works-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px}
.work-card{
  background:var(--glass);backdrop-filter:blur(16px);
  border:1px solid var(--glass-border);padding:44px;
  position:relative;overflow:hidden;transition:all .5s;
  transform-style:preserve-3d;
}
.work-card:hover{border-color:var(--border-h);transform:perspective(800px) translateY(-3px);
  box-shadow:0 12px 40px rgba(232,132,42,.06)}
.work-card::after{
  content:'';position:absolute;bottom:0;left:0;width:0;height:2px;
  background:linear-gradient(90deg,var(--o),var(--o2));
  transition:width .5s cubic-bezier(.16,1,.3,1);box-shadow:0 0 10px rgba(232,132,42,.3);
}
.work-card:hover::after{width:100%}
.wc-industry{font-family:'Space Mono',monospace;font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--o);margin-bottom:16px;opacity:.5}
.wc-title{font-family:'Syne',sans-serif;font-size:19px;font-weight:700;line-height:1.4;margin-bottom:14px}
.wc-body{font-size:13px;color:var(--text);line-height:2}
.wc-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:20px}
.wc-tag{font-family:'Space Mono',monospace;font-size:9px;padding:4px 10px;background:rgba(232,132,42,.05);color:var(--o);letter-spacing:.04em;border:1px solid rgba(232,132,42,.08)}

.work-featured{
  background:var(--glass);backdrop-filter:blur(20px);
  border:1px solid rgba(232,132,42,.12);
  padding:56px;margin-bottom:2px;position:relative;overflow:hidden;
}
.work-featured::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--o),transparent);
  box-shadow:0 0 30px rgba(232,132,42,.4);
}
.wf-badge{
  font-family:'Space Mono',monospace;font-size:10px;letter-spacing:.15em;
  text-transform:uppercase;color:var(--o);display:inline-flex;align-items:center;gap:8px;margin-bottom:24px;
}
.wf-badge::before{content:'';width:8px;height:8px;background:var(--o);border-radius:50%;box-shadow:0 0 10px var(--o-glow);animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.6)}}
.wf-title{font-family:'Syne',sans-serif;font-size:clamp(22px,2.5vw,32px);font-weight:700;line-height:1.3;margin-bottom:18px}
.wf-body{font-size:14px;color:var(--text);line-height:2;max-width:700px}
.wf-metrics{display:flex;gap:40px;margin-top:44px;padding-top:44px;border-top:1px solid var(--border)}
.wf-m-val{font-family:'Syne',sans-serif;font-size:32px;font-weight:800;color:var(--o);text-shadow:0 0 25px rgba(232,132,42,.25)}
.wf-m-label{font-family:'Space Mono',monospace;font-size:10px;color:var(--mu);letter-spacing:.1em;margin-top:6px}

/* ============= BLOG CARDS ============= */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.blog-card{
  background:var(--glass);backdrop-filter:blur(16px);
  border:1px solid var(--glass-border);overflow:hidden;
  transition:all .5s;position:relative;transform-style:preserve-3d;
}
.blog-card:hover{border-color:var(--border-h);transform:perspective(800px) translateY(-3px);
  box-shadow:0 12px 40px rgba(232,132,42,.06)}
.blog-card::after{
  content:'';position:absolute;bottom:0;left:0;width:0;height:2px;
  background:var(--o);transition:width .5s cubic-bezier(.16,1,.3,1);
}
.blog-card:hover::after{width:100%}
.bc-img{height:200px;background:var(--bg4);position:relative;overflow:hidden}
.bc-placeholder{
  width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--bg4),var(--bg3));
  font-family:'Space Mono',monospace;font-size:40px;opacity:.2;
}
.bc-body{padding:28px}
.bc-cat{font-family:'Space Mono',monospace;font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:var(--o);margin-bottom:12px;opacity:.6}
.bc-title{font-family:'Syne',sans-serif;font-size:17px;font-weight:700;line-height:1.4;margin-bottom:10px;transition:color .3s}
.blog-card:hover .bc-title{color:var(--o)}
.bc-excerpt{font-size:12px;color:var(--mu);line-height:1.8}
.bc-meta{font-family:'Space Mono',monospace;font-size:10px;color:var(--mu);margin-top:16px;padding-top:16px;border-top:1px solid var(--border);display:flex;justify-content:space-between}

/* ============= ARTICLE ============= */
.article-content{max-width:720px;margin:0 auto;padding:80px 24px 120px}
.article-content h2{font-family:'Syne',sans-serif;font-size:24px;font-weight:700;margin:48px 0 20px;color:var(--w)}
.article-content h3{font-family:'Syne',sans-serif;font-size:18px;font-weight:700;margin:36px 0 16px;color:var(--w)}
.article-content p{font-size:15px;color:var(--text);line-height:2.2;margin-bottom:20px}
.article-content strong{color:var(--o);font-weight:500}
.article-content blockquote{
  border-left:2px solid var(--o);padding:16px 24px;margin:28px 0;
  background:rgba(232,132,42,.03);font-style:italic;color:var(--li);
  backdrop-filter:blur(8px);
}

/* ============= PROCESS ============= */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;counter-reset:step}
.step{
  background:var(--glass);backdrop-filter:blur(16px);
  padding:44px 32px;position:relative;
  border:1px solid var(--glass-border);transition:all .5s;counter-increment:step;
  transform-style:preserve-3d;
}
.step:hover{border-color:var(--border-h);
  box-shadow:0 8px 30px rgba(232,132,42,.06)}
.step::before{
  content:counter(step,decimal-leading-zero);
  font-family:'Syne',sans-serif;font-size:44px;font-weight:800;
  color:rgba(232,132,42,.06);line-height:1;margin-bottom:20px;display:block;transition:all .3s;
}
.step:hover::before{color:rgba(232,132,42,.2);text-shadow:0 0 20px rgba(232,132,42,.1)}
.step-title{font-family:'Syne',sans-serif;font-size:17px;font-weight:700;margin-bottom:14px}
.step-body{font-size:13px;color:var(--text);line-height:1.9}
.step-arrow{position:absolute;right:-12px;top:50%;transform:translateY(-50%);font-size:18px;color:var(--o);opacity:.2;z-index:2}

/* ============= FAQ ============= */
.faq-list{max-width:800px}
.faq-item{border-bottom:1px solid var(--border);overflow:hidden}
.faq-q{
  padding:24px 0;cursor:pointer;display:flex;justify-content:space-between;align-items:center;
  font-size:15px;font-weight:500;transition:color .3s;user-select:none;
}
.faq-q:hover{color:var(--o)}
.faq-q .icon{font-family:'Space Mono',monospace;font-size:18px;color:var(--o);transition:transform .3s;flex-shrink:0;margin-left:24px}
.faq-item.open .faq-q .icon{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .4s ease}
.faq-item.open .faq-a{max-height:300px;padding-bottom:24px}
.faq-a-inner{font-size:14px;color:var(--text);line-height:2}

/* ============= CONTACT ============= */
.contact-section{position:relative;overflow:hidden}
.contact-glow{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:700px;height:700px;
  background:radial-gradient(circle,rgba(232,132,42,.07) 0%,transparent 50%);pointer-events:none;
}
.contact-title{
  font-family:'Syne',sans-serif;font-size:clamp(44px,7vw,90px);font-weight:800;
  line-height:.95;letter-spacing:-.04em;margin-bottom:56px;
}
.contact-title .orange{color:var(--o);text-shadow:0 0 50px rgba(232,132,42,.25)}
.cl-items{display:flex;flex-direction:column}
.cl-item{
  display:flex;align-items:center;justify-content:space-between;
  padding:24px 0;border-bottom:1px solid var(--border);transition:all .4s cubic-bezier(.16,1,.3,1);
}
.cl-item:hover{padding-left:20px;border-color:var(--border-h)}
.cl-type{font-family:'Space Mono',monospace;font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--o);margin-bottom:5px;opacity:.5}
.cl-val{font-family:'Syne',sans-serif;font-size:20px;font-weight:700}
.cl-arr{font-size:18px;color:var(--o);transition:transform .3s;opacity:.3}
.cl-item:hover .cl-arr{transform:translateX(10px);opacity:1}

/* ============= PAGE HERO ============= */
.page-hero{
  padding:180px 48px 100px;position:relative;overflow:hidden;
  min-height:50vh;display:flex;flex-direction:column;justify-content:flex-end;
}
.page-hero-bg{position:absolute;inset:0;overflow:hidden}
.page-hero-glow{
  position:absolute;top:0;left:50%;transform:translateX(-50%);width:100%;height:100%;
  background:radial-gradient(ellipse 60% 80% at 50% 20%,rgba(232,132,42,.06) 0%,transparent 60%);
  pointer-events:none;
}
.page-hero-title{
  font-family:'Syne',sans-serif;font-size:clamp(40px,6vw,72px);font-weight:800;
  line-height:1;letter-spacing:-.04em;position:relative;z-index:2;
}
.page-hero-title .orange{color:var(--o);text-shadow:0 0 40px rgba(232,132,42,.25)}
.page-hero-sub{font-size:15px;color:var(--text);line-height:2;margin-top:24px;max-width:600px;position:relative;z-index:2}

/* ============= FOOTER ============= */
footer{
  padding:28px 48px;display:flex;justify-content:space-between;align-items:center;
  border-top:1px solid var(--border);background:var(--bg);
}
.f-l{font-family:'Syne',sans-serif;font-weight:800;font-size:18px;color:var(--o);text-shadow:0 0 12px rgba(232,132,42,.2)}
.f-r{font-family:'Space Mono',monospace;font-size:10px;color:var(--mu);letter-spacing:.04em}
.f-links{display:flex;gap:24px;margin-top:8px}
.f-links a{font-family:'Space Mono',monospace;font-size:10px;color:var(--mu);transition:color .3s}
.f-links a:hover{color:var(--o)}

/* ============= GSAP animation initial state ============= */
[data-a]{opacity:0}
[data-stagger]>*{opacity:0}
.glow-divider{transform:scaleX(0)}

/* ============= RESPONSIVE ============= */
@media(max-width:900px){
  body{cursor:auto}
  #cursor-glow,#cursor-dot{display:none}
  nav{padding:16px 24px}
  .nav-links{display:none}
  .hamburger{display:flex}
  .mobile-menu{display:flex}
  .hero{padding:100px 24px 60px}
  .section-pad{padding:80px 24px}
  .page-hero{padding:140px 24px 60px;min-height:35vh}
  .srv-grid,.blog-grid{grid-template-columns:1fr}
  .works-grid{grid-template-columns:1fr}
  .process-grid{grid-template-columns:1fr 1fr}
  .step-arrow{display:none}
  .hero-title{font-size:clamp(36px,11vw,64px)}
  .hero-ctas{flex-direction:column}
  .btn-primary,.btn-secondary{justify-content:center}
  .wf-metrics{flex-wrap:wrap;gap:20px}
  footer{flex-direction:column;gap:12px;padding:24px;text-align:center}
  .work-featured{padding:32px 20px}
}
@media(max-width:600px){
  .process-grid{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr}
}
