:root{
  --ink:#0f0d0c;--paper:#faf8f5;--accent:#ff4e1a;--accent-dark:#cc3300;
  --muted:#7a7370;--border:rgba(15,13,12,0.1);--border-s:rgba(15,13,12,0.2);
  --serif:'Noto Serif TC',serif;--display:'Bebas Neue',sans-serif;--body:'DM Sans',sans-serif;
  --nav-h:60px;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{background:var(--paper);color:var(--ink);font-family:var(--body);overflow-x:hidden;}
img{display:block;max-width:100%;}
/* Touch targets */
a,button{min-height:44px;display:inline-flex;align-items:center;}

/* ── NAV ── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:200;height:var(--nav-h);
  padding:0 40px;display:flex;align-items:center;justify-content:space-between;
  background:var(--paper);border-bottom:1px solid var(--border);
  transition:background .3s,box-shadow .3s;
}
nav.scrolled{background:rgba(250,248,245,.95);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:0 1px 20px rgba(15,13,12,.08);}
.nav-logo{
  font-family:var(--serif);font-weight:900;font-size:16px;
  letter-spacing:.04em;color:var(--ink);text-decoration:none;
  display:flex;align-items:center;gap:8px;min-height:44px;
}
.nav-mark{
  width:28px;height:28px;background:var(--accent);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.nav-mark svg{width:14px;height:14px;}
.nav-desktop{display:flex;align-items:center;gap:4px;}
.nav-desktop a{
  font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--muted);text-decoration:none;padding:0 14px;min-height:44px;
  transition:color .2s;
}
.nav-desktop a:hover,.nav-desktop a:focus{color:var(--ink);}
.nav-drop{position:relative;display:flex;align-items:center;}
.nav-drop-trigger{display:flex;align-items:center;gap:4px;font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);text-decoration:none;padding:0 14px;min-height:44px;transition:color .2s;cursor:default;}
.nav-drop-trigger svg{transition:transform .2s;}
.nav-drop:hover .nav-drop-trigger,.nav-drop-trigger:focus{color:var(--ink);}
.nav-drop:hover .nav-drop-trigger svg{transform:rotate(180deg);}
.nav-drop-menu{position:absolute;top:calc(100% + 4px);left:50%;transform:translateX(-50%) translateY(6px);background:var(--paper);border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 24px rgba(15,13,12,.1);min-width:180px;padding:6px;opacity:0;visibility:hidden;transition:opacity .18s,transform .18s,visibility .18s;z-index:300;}
.nav-drop:hover .nav-drop-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);}
.nav-drop-menu a{display:flex;align-items:center;padding:9px 14px;font-size:12px;letter-spacing:.04em;text-transform:none;color:var(--muted);text-decoration:none;border-radius:5px;min-height:unset;transition:background .12s,color .12s;white-space:nowrap;}
.nav-drop-menu a:hover,.nav-drop-menu a.active{background:rgba(255,78,26,.07);color:var(--ink);}
.nav-cta{padding:0 20px !important;background:var(--accent);color:#fff !important;margin-left:8px;transition:background .2s !important;}
.nav-cta:hover,.nav-cta:focus{background:var(--accent-dark) !important;}
.hamburger{
  display:none;flex-direction:column;gap:5px;justify-content:center;
  width:44px;height:44px;background:none;border:none;cursor:pointer;
  padding:10px;-webkit-tap-highlight-color:transparent;
}
.hamburger span{display:block;width:22px;height:1.5px;background:var(--ink);transition:all .25s;transform-origin:center;}
.hamburger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg);}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0);}
.hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);}
.mobile-nav{
  display:none;position:fixed;top:var(--nav-h);left:0;right:0;bottom:0;
  background:var(--paper);z-index:199;
  flex-direction:column;padding:24px 24px;overflow-y:auto;
  transform:translateX(100%);transition:transform .3s cubic-bezier(.16,1,.3,1);
}
.mobile-nav.open{transform:translateX(0);}
.mobile-nav a{
  font-family:var(--serif);font-weight:600;font-size:28px;
  color:var(--ink);text-decoration:none;padding:14px 0;border-bottom:1px solid var(--border);
  min-height:60px;display:flex;align-items:center;transition:color .2s;
}
.mobile-nav a:hover,.mobile-nav a:focus{color:var(--accent);}
.mobile-nav .m-cta{
  margin-top:20px;background:var(--accent);color:#fff !important;
  justify-content:center;font-family:var(--body) !important;
  font-size:13px !important;font-weight:500 !important;
  letter-spacing:.1em;text-transform:uppercase;min-height:52px;border:none;
}
.mobile-nav .ml-sub{font-size:18px !important;font-weight:500 !important;padding:10px 0 10px 20px !important;min-height:48px !important;color:var(--muted) !important;border-bottom:1px solid var(--border) !important;}
.mobile-nav .ml-sub:hover,.mobile-nav .ml-sub:focus{color:var(--accent) !important;}
.mobile-nav .ml-group{font-family:var(--body) !important;font-size:10px !important;font-weight:600 !important;letter-spacing:.15em;text-transform:uppercase;color:var(--muted) !important;padding:16px 0 4px !important;min-height:unset !important;border-bottom:none !important;pointer-events:none;}

/* ── HERO ── */
.hero{display:grid;grid-template-columns:1fr 1fr;min-height:100vh;padding-top:var(--nav-h);overflow:hidden;}
.hero-l{
  display:flex;flex-direction:column;justify-content:center;
  padding:56px 52px;background:var(--paper);
}
.eyebrow{
  font-size:10px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--muted);margin-bottom:20px;display:flex;align-items:center;gap:10px;
  opacity:0;animation:fadeUp .45s 0s forwards;
}
.eyebrow::before{content:'';width:22px;height:1.5px;background:var(--accent);flex-shrink:0;}
.hero-title{
  font-family:var(--serif);font-weight:900;
  font-size:clamp(46px,5.5vw,88px);
  line-height:1.05;letter-spacing:-.02em;margin-bottom:10px;
  opacity:0;animation:fadeUp .45s .07s forwards;
}
.hero-title .or{color:var(--accent);}
.hero-sub{
  font-family:var(--display);font-size:clamp(17px,2.4vw,34px);
  letter-spacing:.1em;color:var(--muted);margin-bottom:26px;
  opacity:0;animation:fadeUp .45s .12s forwards;
}
.hero-desc{
  font-size:14.5px;line-height:1.85;color:var(--muted);max-width:400px;margin-bottom:24px;
  opacity:0;animation:fadeUp .45s .17s forwards;
}
.hero-awards{
  display:flex;gap:7px;margin-bottom:28px;flex-wrap:wrap;
  opacity:0;animation:fadeUp .45s .2s forwards;
}
.award-badge{
  padding:5px 11px;border:1px solid var(--border-s);
  font-size:9px;letter-spacing:.15em;text-transform:uppercase;
  color:var(--muted);display:flex;align-items:center;gap:5px;
}
.award-badge::before{content:'★';color:var(--accent);}
.hero-cta{display:flex;gap:10px;flex-wrap:wrap;opacity:0;animation:fadeUp .45s .24s forwards;}
.btn-p{
  padding:0 30px;height:48px;background:var(--accent);color:#fff;
  font-size:12px;letter-spacing:.12em;text-transform:uppercase;
  text-decoration:none;display:inline-flex;align-items:center;gap:8px;
  transition:background .2s,transform .15s;font-family:var(--body);font-weight:500;
  -webkit-tap-highlight-color:transparent;
}
.btn-p:hover{background:var(--accent-dark);}
.btn-p:active{transform:scale(.97);}
.btn-p::after{content:'→';}
.btn-g{
  padding:0 20px;height:48px;font-size:12px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);text-decoration:none;border:1px solid var(--border-s);
  display:inline-flex;align-items:center;transition:all .2s;
  -webkit-tap-highlight-color:transparent;
}
.btn-g:hover,.btn-g:focus{color:var(--ink);border-color:var(--ink);}
.btn-g:active{transform:scale(.97);}

/* HERO RIGHT */
.hero-r{background:var(--ink);display:flex;align-items:center;justify-content:center;padding:36px 28px;position:relative;overflow:hidden;}
.grid-mesh{
  position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(255,78,26,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(255,78,26,.07) 1px,transparent 1px);
  background-size:48px 48px;animation:mesh 24s linear infinite;
}
@keyframes mesh{from{background-position:0 0}to{background-position:48px 48px}}
.dashboard{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%;max-width:480px;}
.dc{background:rgba(250,248,245,.04);border:1px solid rgba(255,78,26,.18);border-radius:2px;padding:18px;}
.dl{font-size:9px;letter-spacing:.24em;text-transform:uppercase;color:rgba(255,78,26,.55);margin-bottom:10px;}
.dbig{font-family:var(--display);font-size:56px;color:var(--accent);line-height:1;margin-bottom:4px;}
.dsub{font-size:9px;letter-spacing:.13em;text-transform:uppercase;color:rgba(250,248,245,.22);margin-bottom:12px;}
.dbars{display:flex;flex-direction:column;gap:5px;}
.dbar{height:3px;background:rgba(250,248,245,.07);border-radius:2px;overflow:hidden;}
.dbar-fill{height:100%;background:var(--accent);border-radius:2px;transform:scaleX(0);transform-origin:left;animation:barg 1.2s var(--d,.3s) cubic-bezier(.16,1,.3,1) forwards;}
@keyframes barg{to{transform:scaleX(1)}}
.dpills{display:flex;flex-wrap:wrap;gap:5px;}
.dp{padding:3px 8px;border:1px solid rgba(250,248,245,.12);border-radius:2px;font-size:10px;color:rgba(250,248,245,.4);}
.dp.hot{border-color:rgba(255,78,26,.4);color:var(--accent);background:rgba(255,78,26,.07);}
.dterm{grid-column:1/-1;padding:0;overflow:hidden;}
.dterm-bar{background:rgba(255,255,255,.04);padding:8px 14px;display:flex;align-items:center;gap:6px;border-bottom:1px solid rgba(255,78,26,.1);}
.dot{width:8px;height:8px;border-radius:50%;}
.dot.r{background:#ff5f57}.dot.y{background:#ffbd2e}.dot.g{background:#28c840}
.dterm-ttl{font-size:10px;color:rgba(250,248,245,.22);margin-left:6px;font-family:monospace;}
.dterm-body{padding:14px;font-family:'Courier New',monospace;font-size:11px;line-height:1.9;color:rgba(250,248,245,.55);min-height:90px;}
.tc{color:var(--accent)}.tok{color:#28c840}.tin{color:#60b8ff}
.tcur{display:inline-block;width:7px;height:12px;background:var(--accent);vertical-align:middle;margin-left:1px;animation:blink 1s step-end infinite;}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
.dsvc{grid-column:1/-1;}
.dsvc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;}
.dsvc-item{
  text-align:center;padding:10px 4px;border:1px solid rgba(250,248,245,.06);border-radius:2px;
  transition:border-color .25s,background .25s;
}
/* Touch: active state for tap feedback */
.dsvc-item:hover,.dsvc-item:active{border-color:rgba(255,78,26,.35);background:rgba(255,78,26,.06);}
.dsvc-item span{font-size:18px;display:block;margin-bottom:4px;}
.dsvc-item p{font-size:8.5px;letter-spacing:.09em;color:rgba(250,248,245,.3);text-transform:uppercase;}

/* ── MARQUEE ── */
.marquee{background:var(--accent);padding:13px 0;overflow:hidden;display:flex;}
.marquee-t{display:flex;gap:40px;white-space:nowrap;flex-shrink:0;animation:mq 18s linear infinite;}
.marquee-t span{font-family:var(--display);font-size:19px;letter-spacing:.14em;color:rgba(255,255,255,.75);}
.marquee-t .sep{color:rgba(255,255,255,.4);font-size:11px;align-self:center;}
@keyframes mq{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.marquee-t,.grid-mesh{animation:none;}}

/* ── CLIENTS ── */
.clients{padding:48px 40px;border-bottom:1px solid var(--border);}
.sect-lbl{font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--muted);margin-bottom:26px;display:flex;align-items:center;gap:10px;}
.sect-lbl::before{content:'';width:20px;height:1.5px;background:var(--accent);flex-shrink:0;}
.chips{display:flex;flex-wrap:wrap;gap:7px;}
.chip{
  padding:7px 14px;border:1px solid var(--border);
  font-size:12px;color:var(--muted);transition:all .2s;min-height:36px;
  display:inline-flex;align-items:center;
}
.chip:hover,.chip:active{border-color:var(--accent);color:var(--ink);}
.chip.big{font-weight:500;color:var(--ink);border-color:var(--border-s);}

/* ── SERVICES ── */
.services{background:var(--ink);color:var(--paper);padding:96px 40px;}
.services .sect-lbl{color:rgba(250,248,245,.35);}
.services .sect-lbl::before{background:var(--accent);}
.srv-hdr{display:grid;grid-template-columns:1fr 1fr;gap:60px;margin-bottom:60px;align-items:end;}
.srv-hdr h2{font-family:var(--serif);font-size:clamp(34px,4.5vw,62px);font-weight:900;line-height:1.1;letter-spacing:-.02em;}
.srv-hdr h2 em{font-style:normal;color:var(--accent);}
.srv-hdr p{font-size:14px;line-height:1.9;color:rgba(250,248,245,.45);padding-top:10px;}
.srv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(250,248,245,.08);}
.srv-card{
  background:var(--ink);padding:38px 30px;position:relative;overflow:hidden;
  transition:background .3s;
}
.srv-card::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--accent);transition:width .4s;}
.srv-card:hover::after,.srv-card:focus-within::after{width:100%;}
.srv-card:hover,.srv-card:focus-within{background:#161410;}
/* Touch active feedback */
.srv-card:active{background:#161410;}
.srv-num{font-family:var(--display);font-size:32px;color:rgba(250,248,245,.5);line-height:1;margin-bottom:12px;letter-spacing:.05em;}
.srv-ico{font-size:24px;margin-bottom:14px;}
.srv-card h3{font-family:var(--serif);font-size:19px;font-weight:600;margin-bottom:10px;color:var(--paper);}
.srv-card p{font-size:13px;line-height:1.8;color:rgba(250,248,245,.4);}
.stags{display:flex;flex-wrap:wrap;gap:5px;margin-top:16px;}
.stag{padding:4px 9px;border:1px solid rgba(250,248,245,.1);font-size:9px;letter-spacing:.13em;text-transform:uppercase;color:rgba(250,248,245,.3);}
.srv-card.hl{background:var(--accent);}
.srv-card.hl:hover,.srv-card.hl:focus-within,.srv-card.hl:active{background:var(--accent-dark);}
.srv-card.hl h3{color:#fff;}
.srv-card.hl p{color:rgba(255,255,255,.65);}
.srv-card.hl .stag{border-color:rgba(255,255,255,.25);color:rgba(255,255,255,.6);}
.srv-card.hl .srv-num{color:rgba(255,255,255,.4);}
.srv-card.hl::after{background:#fff;}

/* ── WORKS ── */
.works{background:var(--paper);padding:96px 40px;}
.works-hdr{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:44px;}
.works-hdr h2{font-family:var(--serif);font-size:clamp(30px,4vw,54px);font-weight:900;letter-spacing:-.02em;line-height:1.1;}
.see-all{
  font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);
  text-decoration:none;min-height:44px;display:inline-flex;align-items:center;gap:5px;
  padding:0 4px;transition:color .2s;
}
.see-all:hover,.see-all:focus{color:var(--ink);}
.see-all::after{content:'→';}
.wgrid{display:grid;grid-template-columns:1.35fr 1fr;grid-template-rows:1fr 1fr;gap:3px;}
.wcard{position:relative;overflow:hidden;background:var(--ink);}
.wcard.tall{grid-row:span 2;}
.wimg{width:100%;min-height:260px;height:100%;display:flex;align-items:center;justify-content:center;transition:transform .55s cubic-bezier(.16,1,.3,1);}
.wcard:hover .wimg,.wcard:active .wimg{transform:scale(1.04);}
.wcard.tall .wimg{min-height:520px;}
.wcard:nth-child(1) .wimg{background:linear-gradient(135deg,#1c0a04,#2e1008);}
.wcard:nth-child(2) .wimg{background:linear-gradient(135deg,#081018,#0f2038);}
.wcard:nth-child(3) .wimg{background:linear-gradient(135deg,#0e0e14,#1a1a24);}
.wvis{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;}
/* iprimo */
.vi{display:flex;flex-direction:column;align-items:center;gap:14px;}
.vi-logo{font-family:var(--display);font-size:42px;letter-spacing:.1em;color:rgba(255,255,255,.1);}
.vi-bars{display:flex;gap:4px;align-items:flex-end;}
.vi-bar{width:6px;border-radius:2px;background:linear-gradient(to top,var(--accent),rgba(255,112,67,.3));animation:vb 2s ease-in-out infinite;}
@keyframes vb{0%,100%{transform:scaleY(1)}50%{transform:scaleY(.35)}}
.vi-aw{font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,78,26,.55);}
/* suzuki */
.sz{position:relative;display:flex;align-items:center;justify-content:center;}
.sz-bg{font-family:var(--display);font-size:130px;color:rgba(255,255,255,.04);position:absolute;}
.sz-ring{width:100px;height:100px;border:2px solid rgba(255,78,26,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative;z-index:1;animation:spn 12s linear infinite;}
.sz-ring::before{content:'';width:66px;height:66px;border:2px solid rgba(255,78,26,.55);border-radius:50%;position:absolute;}
.sz-dot{width:16px;height:16px;background:var(--accent);border-radius:50%;}
.karma-vis{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;}
.karma-bg{font-family:var(--display);font-size:130px;color:rgba(255,255,255,.04);position:absolute;line-height:1;}
.karma-ring{width:80px;height:80px;border:2px solid rgba(52,199,145,.35);border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative;z-index:1;animation:spn 14s linear infinite;}
.karma-ring::before{content:'';width:54px;height:54px;border:2px solid rgba(52,199,145,.6);border-radius:50%;position:absolute;}
.karma-cross{position:relative;width:20px;height:20px;}
.karma-cross-v{position:absolute;left:50%;top:0;transform:translateX(-50%);width:4px;height:20px;background:#34c791;border-radius:2px;}
.karma-cross-h{position:absolute;top:50%;left:0;transform:translateY(-50%);width:20px;height:4px;background:#34c791;border-radius:2px;}
.karma-label{font-family:var(--display);font-size:11px;letter-spacing:.25em;color:rgba(52,199,145,.7);position:relative;z-index:1;}
@keyframes spn{from{transform:rotate(0)}to{transform:rotate(360deg)}}
/* auo */
.auo-g{display:grid;grid-template-columns:repeat(5,1fr);gap:5px;padding:30px;width:100%;}
.auo-c{background:rgba(96,184,255,.08);border-radius:2px;aspect-ratio:1;animation:auop 2.5s ease-in-out infinite;}
.mgr-vis{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;}
.mgr-ring{position:relative;width:90px;height:90px;animation:spn 8s linear infinite;}
.mgr-dot{position:absolute;width:10px;height:10px;border-radius:50%;background:var(--accent);top:50%;left:50%;transform-origin:0 0;transform:rotate(calc(var(--i)*60deg)) translateX(38px) translateY(-50%);opacity:calc(0.3 + var(--i)*0.12);}
.mgr-label{font-family:var(--display);font-size:12px;letter-spacing:.25em;color:rgba(255,255,255,.5);}
@keyframes auop{0%,100%{opacity:.25}50%{opacity:1}}
/* overlay */
.woverlay{
  position:absolute;bottom:0;left:0;right:0;padding:22px 26px;
  background:linear-gradient(to top,rgba(15,13,12,.9) 0%,transparent 100%);
  opacity:0;transform:translateY(6px);transition:all .3s;
}
.wcard:hover .woverlay,.wcard:active .woverlay{opacity:1;transform:translateY(0);}
/* Always show on touch devices */
@media(hover:none){.woverlay{opacity:1;transform:translateY(0);}}
.woverlay h3{font-family:var(--serif);font-size:16px;font-weight:600;color:var(--paper);margin-bottom:3px;}
.woverlay p{font-size:11px;color:rgba(250,248,245,.45);letter-spacing:.06em;}
.wtag{position:absolute;top:14px;left:14px;padding:4px 9px;background:rgba(15,13,12,.6);backdrop-filter:blur(6px);font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:var(--paper);}
.waward{position:absolute;top:14px;right:14px;padding:4px 9px;background:var(--accent);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:#fff;}
/* DHL */
.dhl-row{margin-top:3px;}
.dhlcard{background:var(--ink);position:relative;overflow:hidden;padding:48px 40px;display:flex;align-items:center;gap:52px;min-height:190px;}
.dhl-bg{position:absolute;font-family:var(--display);font-size:140px;color:rgba(255,78,26,.04);white-space:nowrap;right:24px;top:50%;transform:translateY(-50%);pointer-events:none;user-select:none;}
.dhl-dots{position:absolute;inset:0;overflow:hidden;pointer-events:none;}
.ddot{position:absolute;width:6px;height:6px;background:var(--accent);border-radius:50%;}
.ddot::after{content:'';position:absolute;inset:-5px;border:1px solid var(--accent);border-radius:50%;animation:ping 2.5s ease-out infinite;opacity:0;}
@keyframes ping{0%{opacity:.7;transform:scale(1)}100%{opacity:0;transform:scale(2.5)}}
.dhl-info{position:relative;z-index:1;}
.dhl-cat{font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,78,26,.55);margin-bottom:10px;display:block;}
.dhl-info h3{font-family:var(--serif);font-size:clamp(20px,3vw,30px);font-weight:600;color:var(--paper);margin-bottom:7px;line-height:1.2;}
.dhl-info p{font-size:13px;color:rgba(250,248,245,.38);}

/* ── AWARDS ── */
.awards{background:var(--ink);padding:96px 40px;color:var(--paper);}
.awards .sect-lbl{color:rgba(250,248,245,.35);}
.awgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(250,248,245,.06);}
.awcard{background:var(--ink);padding:34px 30px;border-left:3px solid transparent;transition:background .3s,border-color .3s;}
.awcard:hover,.awcard:active{background:#161410;border-color:var(--accent);}
.aw-type{font-family:var(--display);font-size:13px;letter-spacing:.18em;color:var(--accent);margin-bottom:7px;}
.aw-title{font-family:var(--serif);font-size:17px;font-weight:600;color:var(--paper);margin-bottom:5px;line-height:1.3;}
.aw-from{font-size:11px;color:rgba(250,248,245,.28);}
.aw-works{font-size:10px;color:rgba(250,248,245,.18);margin-top:12px;line-height:1.6;}

/* ── ABOUT ── */
.about{padding:96px 40px;background:var(--paper);}
.about-in{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start;}
.about h2{font-family:var(--serif);font-size:clamp(30px,4vw,52px);font-weight:900;line-height:1.1;letter-spacing:-.02em;margin-bottom:22px;}
.about h2 em{font-style:normal;color:var(--accent);}
.about p{font-size:14px;line-height:1.95;color:var(--muted);margin-bottom:14px;}
.stats{display:grid;grid-template-columns:1fr 1fr;gap:1px;margin-top:36px;background:var(--border);}
.stat{padding:22px 18px;background:var(--paper);}
.stat-n{font-family:var(--display);font-size:42px;color:var(--accent);line-height:1;margin-bottom:4px;}
.stat-l{font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);}
.about-vis{background:var(--ink);position:relative;overflow:hidden;padding:44px 28px;display:flex;flex-direction:column;align-items:center;}
.about-gbg{position:absolute;inset:0;pointer-events:none;background-image:linear-gradient(rgba(255,78,26,.055) 1px,transparent 1px),linear-gradient(90deg,rgba(255,78,26,.055) 1px,transparent 1px);background-size:38px 38px;}
.about-yr{position:absolute;font-family:var(--display);font-size:100px;color:rgba(255,78,26,.06);bottom:12px;right:12px;line-height:1;pointer-events:none;}
.about-big{position:relative;z-index:1;text-align:center;margin-bottom:30px;}
.about-bign{font-family:var(--display);font-size:76px;color:var(--accent);line-height:1;}
.about-bigs{font-size:9px;letter-spacing:.2em;color:rgba(250,248,245,.33);text-transform:uppercase;margin-top:4px;}
.tl{position:relative;z-index:1;width:100%;}
.tl-row{display:flex;align-items:flex-start;gap:12px;padding:10px 0;border-bottom:1px solid rgba(250,248,245,.05);}
.tl-yr{font-family:var(--display);font-size:17px;color:var(--accent);width:46px;flex-shrink:0;}
.tl-tx{font-size:11px;color:rgba(250,248,245,.36);line-height:1.5;padding-top:1px;}

/* ── TECH ── */
.tech{background:var(--paper);padding:96px 40px;}
.tech>h2{font-family:var(--serif);font-size:clamp(26px,3.5vw,46px);font-weight:900;letter-spacing:-.02em;margin-bottom:36px;max-width:540px;}
.tech-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);}
.tech-col{background:var(--paper);padding:30px 24px;border-top:3px solid transparent;transition:border-color .3s;}
.tech-col:hover,.tech-col:focus-within,.tech-col:active{border-color:var(--accent);}
.tech-col h4{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:14px;}
.tech-list{display:flex;flex-direction:column;gap:9px;}
.tech-item{display:flex;align-items:center;gap:9px;font-size:13.5px;color:var(--ink);}
.tech-item::before{content:'';width:5px;height:5px;background:var(--accent);border-radius:50%;flex-shrink:0;opacity:.6;}

/* ── CONTACT ── */
.contact{background:var(--accent);color:#fff;padding:96px 40px;position:relative;overflow:hidden;}
.contact-bg{position:absolute;font-family:var(--display);font-size:190px;color:rgba(255,255,255,.07);white-space:nowrap;right:0;top:50%;transform:translateY(-50%);pointer-events:none;}
.contact-in{max-width:640px;position:relative;z-index:1;}
.contact .sect-lbl{color:rgba(255,255,255,.5);}
.contact .sect-lbl::before{background:rgba(255,255,255,.5);}
.contact h2{font-family:var(--serif);font-size:clamp(34px,5.5vw,70px);font-weight:900;line-height:1.05;letter-spacing:-.02em;margin-bottom:16px;}
.cdesc{font-size:15px;line-height:1.8;color:rgba(255,255,255,.65);margin-bottom:28px;max-width:420px;}
.cdetails{display:flex;flex-direction:column;gap:9px;margin-bottom:32px;}
.crow{display:flex;align-items:center;gap:12px;font-size:14px;color:rgba(255,255,255,.82);min-height:36px;}
.crow::before{content:'';width:14px;height:1.5px;background:rgba(255,255,255,.4);flex-shrink:0;}
.crow a{color:inherit;text-decoration:none;}
.crow a:hover,.crow a:focus{text-decoration:underline;}
.cbtns{display:flex;gap:10px;flex-wrap:wrap;}
.cbtn{
  padding:0 28px;height:50px;font-size:12px;letter-spacing:.12em;text-transform:uppercase;
  text-decoration:none;display:inline-flex;align-items:center;gap:7px;
  transition:all .2s;font-family:var(--body);font-weight:500;
  -webkit-tap-highlight-color:transparent;
}
.cbtn:active{transform:scale(.97);}
.cb-solid{background:#fff;color:var(--accent);}
.cb-solid:hover,.cb-solid:focus{background:var(--ink);color:#fff;}
.cb-out{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.4);}
.cb-out:hover,.cb-out:focus{background:rgba(255,255,255,.12);}

/* ── FOOTER ── */
footer{background:var(--ink);color:var(--paper);padding:34px 40px;display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;}
.footer-logo{font-family:var(--serif);font-weight:900;font-size:14px;letter-spacing:.04em;}
.footer-logo span{color:var(--accent);}
.footer-mid{font-size:11px;color:rgba(250,248,245,.22);text-align:center;line-height:1.7;}
.footer-links{display:flex;gap:16px;}
.footer-links a{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:rgba(250,248,245,.28);text-decoration:none;min-height:36px;display:inline-flex;align-items:center;transition:color .2s;}
.footer-links a:hover,.footer-links a:focus{color:var(--accent);}

/* ── ANIMATIONS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s,transform .6s cubic-bezier(.16,1,.3,1);}
.reveal.in{opacity:1;transform:translateY(0);}

/* ── FOCUS ── */
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;}

/* ══════════════ TABLET ≤1024 ══════════════ */
@media(max-width:1024px){
  nav{padding:0 24px;}
  .nav-desktop{display:none;}
  .hamburger{display:flex;}
  .mobile-nav{display:flex;}

  .hero{grid-template-columns:1fr;min-height:auto;}
  .hero-l{padding:36px 24px 36px;justify-content:flex-start;}
  .hero-r{padding:28px 24px;}
  .dashboard{max-width:100%;}
  .hero-title{font-size:clamp(42px,11vw,64px);}
  .hero-sub{font-size:clamp(16px,5vw,28px);}
  .dbig{font-size:48px;}

  .clients{padding:38px 24px;}
  .services{padding:72px 24px;}
  .srv-hdr{grid-template-columns:1fr;gap:18px;margin-bottom:40px;}
  .srv-grid{grid-template-columns:1fr 1fr;}

  .works{padding:72px 24px;}
  .wgrid{grid-template-columns:1fr 1fr;}
  .wcard.tall{grid-row:auto;}
  .wcard.tall .wimg{min-height:260px;}
  .dhlcard{flex-direction:column;gap:18px;align-items:flex-start;padding:32px 24px;}
  .dhl-bg{display:none;}

  .awards{padding:72px 24px;}
  .awgrid{grid-template-columns:1fr 1fr;}

  .about{padding:72px 24px;}
  .about-in{grid-template-columns:1fr;gap:36px;}

  .tech{padding:72px 24px;}
  .tech-grid{grid-template-columns:1fr 1fr;}

  .contact{padding:72px 24px;}
  .contact-bg{display:none;}

  footer{grid-template-columns:1fr;text-align:center;padding:26px 24px;gap:10px;}
  .footer-links{justify-content:center;}
}

/* ══════════════ MOBILE ≤600 ══════════════ */
@media(max-width:600px){
  .hero-l{padding:28px 20px 28px;}
  .hero-r{padding:24px 20px;}
  .hero-awards{display:none;}
  .dashboard{grid-template-columns:1fr;}
  .dterm{grid-column:1;}
  .dsvc{grid-column:1;}

  .services{padding:56px 20px;}
  .srv-grid{grid-template-columns:1fr;}

  .works{padding:56px 20px;}
  .wgrid{grid-template-columns:1fr;}
  .dhlcard{padding:28px 20px;}

  .awards{padding:56px 20px;}
  .awgrid{grid-template-columns:1fr 1fr;}

  .about{padding:56px 20px;}
  .stats{grid-template-columns:1fr 1fr;}

  .tech{padding:56px 20px;}
  .tech-grid{grid-template-columns:1fr 1fr;}

  .contact{padding:56px 20px;}
  .cbtns{flex-direction:column;}
  .cbtn{justify-content:center;}

  .clients{padding:32px 20px;}
}

/* ── LOGO ── */
.nav-logo img { height: 24px; width: auto; margin-right: 8px; }
.nav-logo .logo-text { display: inline-block; }

/* ── LIGHTBOX ── */
.lightbox-overlay {
  position: fixed; top: 0; left: 0; width: 100%; height: 100%;
  background: rgba(15, 13, 12, 0.85); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  z-index: 9999; display: flex; align-items: center; justify-content: center;
  opacity: 0; visibility: hidden; transition: all 0.3s ease;
}
.lightbox-overlay.active {
  opacity: 1; visibility: visible;
}
.lightbox-container {
  background: var(--paper); width: 100%; max-width: 540px; padding: 40px;
  border-radius: 8px; position: relative; transform: translateY(20px);
  transition: all 0.3s ease; max-height: 90vh; overflow-y: auto;
}
.lightbox-overlay.active .lightbox-container {
  transform: translateY(0);
}
.lightbox-close {
  position: absolute; top: 20px; right: 20px; background: none; border: none;
  font-size: 24px; cursor: pointer; color: var(--muted); transition: color 0.2s;
  width: 32px; height: 32px; display: flex; align-items: center; justify-content: center;
}
.lightbox-close:hover { color: var(--ink); }
.lightbox-title {
  font-family: var(--serif); font-size: 28px; font-weight: 900; margin-bottom: 8px; color: var(--ink);
}
.lightbox-desc {
  font-size: 14px; color: var(--muted); margin-bottom: 24px;
}
.form-group { margin-bottom: 16px; }
.form-group label {
  display: block; font-size: 12px; font-weight: 500; color: var(--ink); margin-bottom: 6px;
}
.form-control {
  width: 100%; padding: 12px 14px; border: 1px solid var(--border-s); border-radius: 4px;
  font-family: var(--body); font-size: 14px; background: #fff; transition: border-color 0.2s;
}
.form-control:focus {
  outline: none; border-color: var(--accent);
}
textarea.form-control { resize: vertical; min-height: 100px; }
select.form-control { appearance: none; -webkit-appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23888' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 36px; cursor: pointer; }
.btn-submit {
  width: 100%; padding: 14px; background: var(--accent); color: #fff; border: none;
  border-radius: 4px; font-size: 14px; font-weight: 500; letter-spacing: 0.1em;
  cursor: pointer; transition: background 0.2s; display: flex; justify-content: center; align-items: center;
}
.btn-submit:hover { background: var(--accent-dark); }
.btn-submit:disabled { opacity: 0.7; cursor: not-allowed; }
.form-message { margin-top: 16px; font-size: 13px; text-align: center; display: none; }
.form-message.success { color: #28c840; display: block; }
.form-message.error { color: #ff5f57; display: block; }

/* ── 紙飛機動畫 ── */
@keyframes planeFly {
  0%   { transform: translate(0,0) rotate(-70deg) scale(1); opacity: 1; }
  100% { transform: translate(120px,-460px) rotate(-70deg) scale(0.2); opacity: 0; }
}
.plane-el {
  position: fixed; z-index: 99999; pointer-events: none; color: var(--accent);
  filter: drop-shadow(2px 4px 8px rgba(0,0,0,.4));
  animation: planeFly 1.6s cubic-bezier(.2,.0,.15,1) forwards;
}

/* ── 送出成功畫面 ── */
.lb-sent {
  display: none; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; padding: 32px 16px; min-height: 320px;
}
.lb-sent.show { display: flex; animation: fadeUp .5s .15s both; }
.lb-sent-icon {
  width: 72px; height: 72px; border-radius: 50%;
  background: rgba(40,200,64,.1); border: 2px solid rgba(40,200,64,.25);
  display: flex; align-items: center; justify-content: center; margin-bottom: 24px;
  animation: fadeUp .45s .3s both;
}
.lb-sent-icon svg { color: #28c840; }
.lb-sent-title {
  font-family: var(--serif); font-size: 26px; font-weight: 900;
  color: var(--ink); margin-bottom: 10px; animation: fadeUp .45s .4s both;
}
.lb-sent-sub {
  font-size: 14px; color: var(--muted); line-height: 1.8;
  max-width: 260px; animation: fadeUp .45s .5s both;
}
.lb-sent-close {
  margin-top: 28px; padding: 12px 32px; background: var(--accent); color: #fff;
  border: none; border-radius: 6px; font-size: 13px; font-weight: 500;
  cursor: pointer; transition: background .2s; animation: fadeUp .45s .6s both;
  display: inline-flex; align-items: center;
}
.lb-sent-close:hover { background: var(--accent-dark); }
@media(max-width: 600px) {
  .lightbox-container { padding: 30px 20px; width: 90%; }
}
