/* ============================================================
   solara.hk — "Golden Dawn" bright/warm approach
   warm dawn sky · rising luminous sun · earth horizon (火土, bright)
   ============================================================ */

:root{
  /* dawn sky */
  --sky-1:#e9cfc4;   /* soft dusty-rose top */
  --sky-2:#f4cda3;   /* warm peach */
  --sky-3:#ffdca2;   /* bright gold near horizon */
  /* sun */
  --sun-core:#fffaf1;
  --sun-1:#ffd98c;
  --sun-2:#f7a86b;
  /* earth */
  --earth-1:#d18a5b;
  --earth-2:#9d5a35;
  --earth-line:rgba(86,42,18,.16);
  /* ink + accents */
  --ink:#3a291c;
  --ink-2:#5a4634;
  --ink-dim:rgba(58,41,28,.66);
  --ink-faint:rgba(58,41,28,.44);
  --hair:rgba(58,41,28,.14);
  --hair-2:rgba(58,41,28,.08);
  --coral:#e0653f;
  --terra:#c2410c;
  --gold:#e0922f;
  --card:rgba(255,250,243,.66);
  --card-2:rgba(255,248,238,.82);

  --grad-fire: linear-gradient(100deg,#e8703a 0%,#d2480f 52%,#a8330a 100%);
  --shadow-1: 0 2px 8px rgba(120,70,30,.10);
  --shadow-2: 0 18px 50px rgba(120,64,24,.16);

  --font-display: "Space Grotesk", "Noto Sans TC", system-ui, sans-serif;
  --font-mono:    "JetBrains Mono", ui-monospace, monospace;
  --font-han:     "Noto Serif TC", "Noto Sans TC", "PingFang TC", serif;
  --font-body:    "Space Grotesk", "Noto Sans TC", "PingFang TC", system-ui, sans-serif;

  --ease:   cubic-bezier(.32,.72,0,1);
  --ease-2: cubic-bezier(.16,1,.3,1);
  --maxw: 1200px;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ -webkit-text-size-adjust:100%; }
body{ font-family:var(--font-body); background:var(--sky-2); color:var(--ink); line-height:1.6;
  overflow-x:hidden; -webkit-font-smoothing:antialiased; letter-spacing:.005em; }
a{ color:inherit; text-decoration:none; }
svg{ display:block; }
::selection{ background:rgba(224,101,63,.25); }

/* ============ DAWN STAGE ============ */
.stage{ position:fixed; inset:0; z-index:-3; overflow:hidden; pointer-events:none; }
.stage-parallax{ position:absolute; inset:-6%; will-change:transform; }
.stage-canvas{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  background:#0a0e1a url("assets/hero-poster.jpg?v=6") center/cover no-repeat; }
.stage-veil{ position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(255,250,242,.16) 0%, transparent 26%, transparent 72%, rgba(255,242,225,.14) 100%); }
.stage-dim{ position:absolute; inset:0; background:#191108; opacity:0; will-change:opacity; }
.grain{ position:fixed; inset:0; z-index:60; pointer-events:none; opacity:.05; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }

/* ============ NAV (light glass pill) ============ */
.nav{ position:fixed; top:0; left:0; right:0; z-index:100; display:flex; justify-content:center; padding:18px 16px; pointer-events:none; }
.nav-pill{ position:relative; isolation:isolate; pointer-events:auto; display:flex; align-items:center; gap:clamp(18px,3vw,38px);
  padding:9px 9px 9px 20px; border-radius:999px; border:1px solid rgba(255,255,255,.6); box-shadow:var(--shadow-1); }
.nav-pill::before{ content:""; position:absolute; inset:0; border-radius:inherit; z-index:-1;
  background:rgba(255,248,238,.6); backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px); transition:background .4s var(--ease); }
.nav.scrolled .nav-pill::before{ background:rgba(255,248,238,.82); }
.brand{ display:flex; align-items:center; gap:11px; }
.mark{ width:38px; height:31px; flex:none; filter:drop-shadow(0 2px 6px rgba(224,101,63,.35)); }
.mark img{ display:block; width:100%; height:100%; object-fit:contain; }
.mark.sm{ width:32px; height:26px; }
.brand-word{ font-family:var(--font-display); font-weight:600; letter-spacing:.03em; font-size:16px; color:var(--ink); }
.brand-light{ color:var(--terra); margin-left:0; font-weight:500; }

.nav-links{ display:flex; align-items:center; gap:clamp(16px,2.4vw,30px); }
.nav-links a:not(.nav-cta){ font-size:14px; color:var(--ink-dim); position:relative; transition:color .3s var(--ease); }
.nav-links a:not(.nav-cta):hover{ color:var(--ink); }
.nav-links a:not(.nav-cta)::after{ content:""; position:absolute; left:0; bottom:-5px; height:1px; width:0; background:var(--grad-fire); transition:width .35s var(--ease); }
.nav-links a:not(.nav-cta):hover::after{ width:100%; }
.nav-cta{ display:inline-flex; align-items:center; gap:8px; padding:8px 8px 8px 18px; border-radius:999px; background:rgba(255,255,255,.5); border:1px solid var(--hair); font-size:13.5px; color:var(--ink); transition:all .4s var(--ease); }
.nav-cta .ico{ width:24px; height:24px; border-radius:50%; display:grid; place-items:center; background:var(--grad-fire); color:#fff8ee; font-size:13px; transition:transform .4s var(--ease); }
.nav-cta:hover{ background:rgba(255,255,255,.78); }
.nav-cta:hover .ico{ transform:translate(2px,-2px) scale(1.08); }

.nav-toggle{ display:none; width:42px; height:42px; border-radius:50%; background:rgba(255,255,255,.5); border:1px solid var(--hair); cursor:pointer; position:relative; }
.nav-toggle span{ position:absolute; left:11px; width:20px; height:2px; background:var(--ink); border-radius:2px; transition:transform .4s var(--ease), opacity .3s; }
.nav-toggle span:nth-child(1){ top:17px; } .nav-toggle span:nth-child(2){ top:23px; }
.nav-toggle.open span:nth-child(1){ transform:translateY(3px) rotate(45deg); }
.nav-toggle.open span:nth-child(2){ transform:translateY(-3px) rotate(-45deg); }

/* ============ BUTTONS ============ */
.btn{ display:inline-flex; align-items:center; gap:12px; border-radius:999px; font-family:var(--font-body); font-weight:600; font-size:15px; cursor:pointer; transition:transform .4s var(--ease), background .4s var(--ease), border-color .4s var(--ease); border:1px solid transparent; }
.btn-primary{ background:var(--grad-fire); color:#fff8ee; padding:13px 14px 13px 26px; box-shadow:0 12px 30px rgba(224,101,63,.32); }
.btn-primary:hover{ transform:translateY(-2px); } .btn-primary:active{ transform:scale(.98); }
.btn-ico{ width:30px; height:30px; border-radius:50%; background:rgba(255,255,255,.28); display:grid; place-items:center; font-size:15px; transition:transform .45s var(--ease); }
.btn-primary:hover .btn-ico{ transform:translate(3px,-2px) scale(1.08); }
.btn-ghost{ padding:13px 26px; border-color:var(--hair); color:var(--ink); background:rgba(255,255,255,.4); }
.btn-ghost:hover{ border-color:var(--coral); color:var(--terra); transform:translateY(-2px); background:rgba(255,255,255,.62); }
.btn.big{ font-size:clamp(16px,3vw,20px); padding:18px 18px 18px 34px; }
.btn.big .btn-ico{ width:38px; height:38px; }

/* ============ HERO ============ */
.hero{ position:relative; min-height:100dvh; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; padding:140px clamp(20px,5vw,40px) 120px; }
.eyebrow,.tag{ display:inline-block; font-family:var(--font-mono); font-weight:500; font-size:11.5px; letter-spacing:.22em; text-transform:uppercase; color:#ffd29a; padding:7px 15px; border-radius:999px; border:1px solid rgba(255,255,255,.18); background:rgba(255,255,255,.07); }
.hero-inner{ max-width:940px; }
.hero-title{ font-family:var(--font-han); font-weight:700; margin-top:28px; font-size:clamp(44px,8.6vw,104px); line-height:1.04; letter-spacing:.005em; color:var(--ink); text-shadow:0 1px 0 rgba(255,255,255,.3); }
.hero-title .line{ display:block; }
.accent{ background:var(--grad-fire); -webkit-background-clip:text; background-clip:text; color:transparent; }
.hero-sub{ margin:30px auto 0; max-width:620px; font-size:clamp(15px,2.4vw,18px); color:var(--ink-2); }
.hero-cta{ margin-top:42px; display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }
.hero-hint{ position:absolute; left:50%; bottom:96px; transform:translateX(-50%); font-family:var(--font-mono); font-size:10.5px; letter-spacing:.16em; color:var(--ink-faint); }
.scroll-cue{ position:absolute; bottom:34px; left:50%; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:9px; font-family:var(--font-mono); font-size:10px; letter-spacing:.32em; color:var(--ink-faint); }
.scroll-cue .bar{ width:1px; height:42px; background:linear-gradient(var(--terra),transparent); animation:cue 2s var(--ease) infinite; transform-origin:top; }
@keyframes cue{ 0%{ transform:scaleY(0); opacity:0 } 40%{ transform:scaleY(1); opacity:1 } 100%{ transform:scaleY(1) translateY(42px); opacity:0 } }

/* ===== dark pre-dawn hero: light text + AI constellation (fades as sun rises) ===== */
.hero .eyebrow{ color:#fff3e0; background:rgba(255,255,255,.09); border-color:rgba(255,255,255,.22); }
.hero-title{ color:#fdf6ec; text-shadow:0 2px 34px rgba(0,0,0,.55); }
.hero-title .accent{ background:linear-gradient(100deg,#ffe0a0 0%,#ffac5e 50%,#ff8a3a 100%); -webkit-background-clip:text; background-clip:text; color:transparent;
  filter:drop-shadow(0 2px 18px rgba(20,8,2,.6)); }
/* content-section accents: bright warm gold so they pop on the warm-dark bg */
.section-title .accent, .contact-title .accent{
  background:linear-gradient(100deg,#ffd98a 0%,#ffac5e 50%,#ff8a3a 100%);
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent;
  filter:drop-shadow(0 2px 12px rgba(0,0,0,.5)); }
.hero-sub{ color:rgba(253,246,236,.85); text-shadow:0 2px 16px rgba(0,0,0,.5); }
.hero .btn-ghost{ color:#fdf6ec; border-color:rgba(255,255,255,.3); background:rgba(255,255,255,.09); }
.hero .btn-ghost:hover{ border-color:#ffd98a; color:#ffe9c8; background:rgba(255,255,255,.15); }
.hero-hint{ color:rgba(253,246,236,.55); }
.scroll-cue{ color:rgba(253,246,236,.6); }
.scroll-cue .bar{ background:linear-gradient(rgba(255,230,190,.95),transparent); }

.stage-ai{ position:absolute; left:50%; top:7%; width:min(1120px,92vw); height:48%; transform:translateX(-50%); pointer-events:none; will-change:opacity; filter:drop-shadow(0 0 6px rgba(255,200,130,.5)); }
.stage-ai svg{ width:100%; height:100%; overflow:visible; }
.stage-ai .node{ fill:#ffe6b8; animation:twinkle 4s ease-in-out infinite; }
.stage-ai .node:nth-child(2n){ animation-duration:5.5s; }
.stage-ai .node:nth-child(3n){ animation-duration:6.5s; }
.stage-ai .link{ stroke:rgba(255,222,162,.32); stroke-width:1; }
@keyframes twinkle{ 0%,100%{ opacity:.45 } 50%{ opacity:1 } }

/* digital terrain grid — perspective scan over the valley (dark hero), fades on scroll */
.terrain-grid{ position:absolute; left:50%; bottom:-2%; width:260%; height:44%;
  transform:translateX(-50%) perspective(380px) rotateX(75deg); transform-origin:bottom center; pointer-events:none; opacity:.5;
  background-image:linear-gradient(rgba(255,206,138,.5) 1px, transparent 1px), linear-gradient(90deg, rgba(255,206,138,.32) 1px, transparent 1px);
  background-size:46px 46px;
  -webkit-mask-image:linear-gradient(transparent 0%, #000 58%); mask-image:linear-gradient(transparent 0%, #000 58%);
  animation:gridflow 6s linear infinite; }
@keyframes gridflow{ from{ background-position:0 0 } to{ background-position:0 46px } }

/* Mono HUD telemetry frame */
.hud{ position:fixed; inset:0; z-index:40; pointer-events:none; font-family:var(--font-mono); font-size:10.5px;
  letter-spacing:.14em; color:rgba(253,246,236,.62); text-transform:uppercase; will-change:opacity; }
.hud > div{ position:absolute; display:flex; align-items:center; gap:7px; }
.hud-tl{ top:74px; left:30px; } .hud-tr{ top:74px; right:30px; }
.hud-bl{ bottom:28px; left:30px; } .hud-br{ bottom:28px; right:30px; }
.hud-bl b{ color:#ffd98a; font-weight:500; }
.hud-dot{ width:6px; height:6px; border-radius:50%; background:#ffce8a; box-shadow:0 0 8px #ffce8a; animation:pulse 2s ease-in-out infinite; }
.hud-corner{ position:absolute; width:16px; height:16px; border:1px solid rgba(255,255,255,.28); }
.hud-corner.tl{ top:64px; left:20px; border-right:0; border-bottom:0; }
.hud-corner.tr{ top:64px; right:20px; border-left:0; border-bottom:0; }
.hud-corner.bl{ bottom:18px; left:20px; border-right:0; border-top:0; }
.hud-corner.br{ bottom:18px; right:20px; border-left:0; border-top:0; }
@media (max-width:680px){ .hud-tr, .hud-br, .hud-corner{ display:none; } .hud-tl{ left:20px; } .hud-bl{ left:20px; } }

/* ===== tech UI: about terminal + tech stack + module cards ===== */
.about-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(28px,5vw,58px); align-items:center; margin-top:6px; }
.about-copy .section-title{ margin-top:14px; }
.lede b{ color:#fff7ec; font-weight:600; }

.terminal{ border-radius:16px; overflow:hidden; background:#0e1118; border:1px solid rgba(20,12,4,.3);
  box-shadow:0 26px 64px rgba(70,36,12,.30); font-family:var(--font-mono); }
.term-bar{ display:flex; align-items:center; gap:7px; padding:11px 14px; background:#161b25; border-bottom:1px solid rgba(255,255,255,.06); }
.term-bar > span{ width:11px; height:11px; border-radius:50%; background:#3a4250; }
.term-bar > span:nth-child(1){ background:#ff5f57; } .term-bar > span:nth-child(2){ background:#febc2e; } .term-bar > span:nth-child(3){ background:#28c840; }
.term-bar em{ margin-left:auto; font-style:normal; font-size:11px; color:rgba(255,255,255,.42); letter-spacing:.06em; }
.term-body{ padding:18px 18px 20px; font-size:13px; line-height:2.05; color:rgba(233,240,255,.82); overflow-x:auto; }
.term-body p{ white-space:nowrap; }
.term-body .tp{ color:#7fd0ff; } .term-body .tpc{ color:#9aa7bd; } .term-body .tc{ color:rgba(233,240,255,.55); } .term-body .tok{ color:#3ee07a; }
.cursor{ display:inline-block; width:8px; height:15px; background:#ffce8a; vertical-align:-2px; animation:blink 1.1s steps(1) infinite; }
@keyframes blink{ 50%{ opacity:0 } }

.stack-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:48px; }
.stack-col{ padding:24px 22px; border-radius:18px; border:1px solid var(--hair-2); background:var(--card); box-shadow:var(--shadow-1); }
.stack-col h4{ font-family:var(--font-mono); font-size:12px; letter-spacing:.1em; color:var(--terra); margin-bottom:16px; font-weight:500; }
.stack-col .chips{ flex-direction:column; align-items:flex-start; gap:9px; margin-top:0; }
.stack-col .chips span{ font-size:12.5px; }

.cell-no::before{ content:"▸ "; color:var(--coral); }

.approach-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:48px; perspective:1300px; }

@media (max-width:900px){ .about-grid{ grid-template-columns:1fr; } .stack-grid{ grid-template-columns:repeat(2,1fr); } .approach-grid{ grid-template-columns:1fr; } }
@media (max-width:560px){ .stack-grid{ grid-template-columns:1fr; } }

/* ============ SECTIONS ============ */
.section{ position:relative; padding:clamp(96px,15vh,168px) clamp(20px,5vw,40px); }
.wrap{ max-width:var(--maxw); margin:0 auto; }
.section-title{ font-family:var(--font-han); font-weight:900; font-size:clamp(31px,5.6vw,62px); line-height:1.14; margin:20px 0 30px; color:#f6efe4; text-shadow:0 2px 24px rgba(0,0,0,.55), 0 1px 3px rgba(0,0,0,.45); }
.lede{ max-width:700px; font-size:clamp(15px,2.3vw,19px); color:rgba(245,238,228,.84); line-height:1.85; text-shadow:0 1px 14px rgba(0,0,0,.5); }
.lede b{ color:#fff7ec; }

/* stats */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:64px; }
.stat{ padding:30px 20px; border-radius:20px; border:1px solid var(--hair-2); background:var(--card); box-shadow:var(--shadow-1); text-align:center; }
.stat .num{ display:block; font-family:var(--font-mono); font-weight:500; font-size:clamp(34px,5.4vw,54px); line-height:1; background:var(--grad-fire); -webkit-background-clip:text; background-clip:text; color:transparent; }
.stat .lab{ display:block; margin-top:12px; font-size:13px; color:var(--ink-dim); letter-spacing:.04em; }

/* ============ CELLS + TILT ============ */
.bento, .work-grid{ perspective:1300px; }
.cell{ padding:6px; border-radius:26px; background:rgba(255,255,255,.4); border:1px solid var(--hair-2); transform-style:preserve-3d; transition:transform .5s var(--ease), border-color .5s var(--ease), box-shadow .5s var(--ease); will-change:transform; box-shadow:var(--shadow-1); }
.cell-core{ position:relative; height:100%; padding:50px 28px 30px; border-radius:21px; overflow:hidden; background:var(--card-2); box-shadow:inset 0 1px 0 rgba(255,255,255,.7); }
/* app-window title bar */
.cell-core::before{ content:""; position:absolute; top:0; left:0; right:0; height:37px; background:rgba(255,252,247,.62); border-bottom:1px solid var(--hair-2); border-radius:21px 21px 0 0; transition:border-color .4s var(--ease); }
/* macOS traffic lights (default) */
.cell-core::after{ content:""; position:absolute; top:13px; left:19px; width:10px; height:10px; border-radius:50%; background:#ff5f57; box-shadow:17px 0 0 #febc2e, 34px 0 0 #28c840; }
/* Windows-style controls on alternating cards */
.bento .cell:nth-child(even) .cell-core::after,
.work-grid .cell:nth-child(even) .cell-core::after,
.approach-grid .cell:nth-child(even) .cell-core::after{
  content:"\2013    \25A1    \2715"; top:9px; left:auto; right:16px; width:auto; height:auto; border-radius:0; background:none; box-shadow:none;
  font-family:var(--font-mono); font-size:13px; color:var(--ink-faint); letter-spacing:.5px; }
.cell:hover{ border-color:rgba(224,101,63,.4); box-shadow:var(--shadow-2); }
.cell:hover .cell-core::before{ border-bottom-color:rgba(224,101,63,.5); }

.bento{ display:grid; grid-template-columns:repeat(6,1fr); gap:18px; margin-top:56px; }
.bento .cell:nth-child(1){ grid-column:span 4; }
.bento .cell:nth-child(2){ grid-column:span 2; }
.bento .cell:nth-child(3){ grid-column:span 2; }
.bento .cell:nth-child(4){ grid-column:span 4; }
.bento .cell:nth-child(5){ grid-column:span 3; }
.bento .cell:nth-child(6){ grid-column:span 3; }
.cell-no{ font-family:var(--font-mono); font-weight:500; font-size:13px; color:var(--coral); letter-spacing:.08em; }
.cell-core h3{ font-family:var(--font-han); font-weight:700; font-size:clamp(19px,2.4vw,24px); margin:12px 0 12px; color:var(--ink); }
.cell-core p{ font-size:14.5px; color:var(--ink-dim); line-height:1.72; }
.chips{ display:flex; flex-wrap:wrap; gap:8px; margin-top:20px; }
.chips span{ font-family:var(--font-mono); font-size:11px; color:var(--ink-dim); padding:5px 11px; border-radius:8px; border:1px solid var(--hair-2); background:rgba(255,255,255,.5); }

/* ===== services — dark showcase bento (real work) ===== */
.svc-bento{ display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-top:52px; }
.svc-card{ position:relative; display:flex; flex-direction:column; padding:26px 26px 24px; border-radius:24px; overflow:hidden;
  background:linear-gradient(160deg, rgba(28,18,11,.92), rgba(16,10,7,.95)); border:1px solid rgba(255,180,110,.16);
  box-shadow:0 26px 60px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,210,150,.08); color:#f3e8da;
  transition:transform .5s var(--ease), border-color .5s var(--ease), box-shadow .5s var(--ease); will-change:transform; }
.svc-card::before{ content:""; position:absolute; inset:0; border-radius:inherit; pointer-events:none;
  background:radial-gradient(120% 90% at 100% 0%, rgba(255,150,70,.16), transparent 55%); }
.svc-card:hover{ transform:translateY(-5px); border-color:rgba(255,170,90,.42); box-shadow:0 34px 74px rgba(0,0,0,.42); }
.js .svc-card.reveal{ transform:translateY(64px) scale(.955); filter:blur(6px); }
.svc-web{ grid-row:span 1; }
.svc-head{ position:relative; z-index:2; display:flex; gap:14px; align-items:flex-start; }
.svc-no{ font-family:var(--font-mono); font-weight:500; font-size:13px; color:#ffb066; letter-spacing:.1em; padding-top:3px; }
.svc-no::before{ content:""; }
.svc-head h3{ font-family:var(--font-han); font-weight:700; font-size:clamp(19px,2.2vw,23px); color:#fff6ec; margin-bottom:7px; }
.svc-head p{ font-size:13.5px; line-height:1.66; color:rgba(243,232,218,.66); }
.svc-visual{ position:relative; z-index:2; flex:1; margin:22px 0 18px; min-height:160px; display:flex; align-items:center; justify-content:center; }
.svc-chips{ position:relative; z-index:2; display:flex; flex-wrap:wrap; gap:7px; }
.svc-chips span{ font-family:var(--font-mono); font-size:10.5px; color:rgba(255,210,160,.78); padding:5px 10px; border-radius:7px; border:1px solid rgba(255,180,110,.2); background:rgba(255,170,90,.06); }

/* device frames + screenshots */
.dev-bar{ display:flex; gap:5px; padding:7px 10px; background:#1b120c; }
.dev-bar i{ width:7px; height:7px; border-radius:50%; background:#ff5f57; }
.dev-bar i:nth-child(2){ background:#febc2e; } .dev-bar i:nth-child(3){ background:#28c840; }
.devices{ flex:none!important; height:194px; align-items:flex-end; justify-content:flex-start; overflow:hidden; }
.dev-laptop{ position:absolute; left:0; bottom:6px; width:72%; border-radius:9px 9px 4px 4px; overflow:hidden; border:1px solid rgba(255,200,150,.22); box-shadow:0 18px 36px rgba(0,0,0,.5); background:#120c08; }
.dev-laptop img{ display:block; width:100%; height:144px; object-fit:cover; object-position:top center; }
.dev-phone{ position:absolute; right:0; bottom:0; width:26%; border-radius:15px; overflow:hidden; border:3px solid #241813; box-shadow:0 16px 30px rgba(0,0,0,.55); background:#120c08; z-index:2; }
.dev-phone img{ display:block; width:100%; height:158px; object-fit:cover; object-position:top center; }
.dev-browser{ width:100%; border-radius:11px; overflow:hidden; border:1px solid rgba(255,200,150,.22); box-shadow:0 18px 38px rgba(0,0,0,.5); background:#0e0a07; }
.dev-browser img{ display:block; width:100%; }

/* SEO analytics card */
.analytics{ flex-direction:column; align-items:stretch; gap:16px; }
.an-row{ display:flex; align-items:center; justify-content:space-between; gap:12px; }
.an-stat{ display:flex; flex-direction:column; gap:3px; }
.an-lab{ font-family:var(--font-mono); font-size:10.5px; letter-spacing:.12em; text-transform:uppercase; color:rgba(243,232,218,.55); }
.an-val{ font-family:var(--font-display); font-weight:700; font-size:34px; color:#ffce8a; line-height:1; }
.an-trend{ font-family:var(--font-mono); font-size:11px; color:#7fe0a3; }
.an-score{ position:relative; width:80px; height:80px; flex:none; display:grid; place-items:center; }
.an-score svg{ position:absolute; inset:0; transform:rotate(-90deg); }
.an-score .ring-bg{ fill:none; stroke:rgba(255,255,255,.1); stroke-width:6; }
.an-score .ring-fg{ fill:none; stroke:#ffb066; stroke-width:6; stroke-linecap:round; stroke-dasharray:214; stroke-dashoffset:26; }
.an-num{ font-family:var(--font-display); font-weight:700; font-size:24px; color:#fff6ec; }
.an-cap{ position:absolute; bottom:-16px; font-family:var(--font-mono); font-size:9.5px; letter-spacing:.1em; color:rgba(243,232,218,.5); white-space:nowrap; }
.an-chart{ width:100%; height:96px; }
.an-area{ fill:url(#agrad); }
.an-line{ fill:none; stroke:#ff9a4d; stroke-width:2.4; stroke-linecap:round; stroke-linejoin:round; filter:drop-shadow(0 2px 6px rgba(255,140,60,.5)); }

/* content / media card */
.media{ flex-direction:column; align-items:stretch; gap:14px; }
.media-video{ position:relative; height:128px; border-radius:13px; overflow:hidden; display:grid; place-items:center;
  background:linear-gradient(135deg,#3a1f12,#7a3a1a 55%,#e07a36); border:1px solid rgba(255,200,150,.22); }
.media-video .play{ width:46px; height:46px; border-radius:50%; display:grid; place-items:center; font-size:15px; color:#3a1f12;
  background:rgba(255,245,232,.92); box-shadow:0 8px 22px rgba(0,0,0,.4); padding-left:3px; }
.media-tag{ position:absolute; left:12px; bottom:10px; font-family:var(--font-mono); font-size:10px; letter-spacing:.08em; color:rgba(255,245,232,.92); }
.media-wave{ display:flex; align-items:center; gap:3px; height:34px; }
.media-wave i{ flex:1; border-radius:2px; background:linear-gradient(#ffce8a,#ff8a3a); opacity:.85;
  height:30%; animation:wave 1.4s ease-in-out infinite; }
.media-wave i:nth-child(odd){ animation-delay:-.7s; } .media-wave i:nth-child(3n){ animation-delay:-.4s; } .media-wave i:nth-child(4n){ animation-delay:-1s; }
@keyframes wave{ 0%,100%{ height:22%; } 50%{ height:92%; } }

/* remaining two service lines */
.svc-extra{ display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-top:20px; }
.svc-mini{ display:flex; gap:14px; align-items:flex-start; padding:20px 22px; border-radius:18px; background:var(--card-2); border:1px solid var(--hair-2); box-shadow:var(--shadow-1); }
.svc-mini .svc-no{ color:var(--coral); padding-top:2px; }
.svc-mini b{ font-family:var(--font-han); font-weight:700; font-size:16px; color:var(--ink); display:block; margin-bottom:5px; }
.svc-mini p{ font-size:13.5px; color:var(--ink-dim); line-height:1.6; }

@media (max-width:760px){
  .svc-bento, .svc-extra{ grid-template-columns:1fr; }
}

/* work grid */
.work-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:56px; }
.work-card .cell-core{ display:flex; flex-direction:column; }
.work-top{ display:flex; align-items:center; gap:9px; font-family:var(--font-mono); font-size:11px; letter-spacing:.1em; color:var(--ink-dim); text-transform:uppercase; margin-bottom:18px; }
.dot{ width:7px; height:7px; border-radius:50%; background:var(--ink-faint); }
.dot.live{ background:var(--coral); box-shadow:0 0 8px var(--coral); animation:pulse 2s ease-in-out infinite; }
@keyframes pulse{ 0%,100%{ opacity:1 } 50%{ opacity:.4 } }
.work-cat{ margin-left:auto; color:var(--ink-faint); letter-spacing:.06em; }
.work-card h3{ font-family:var(--font-han); font-weight:700; font-size:20px; margin-bottom:10px; color:var(--ink); }
.work-card p{ font-size:14px; color:var(--ink-dim); line-height:1.7; flex:1; }
.work-link{ margin-top:20px; font-family:var(--font-mono); font-size:12.5px; color:var(--terra); display:inline-flex; align-items:center; gap:6px; }
.work-link i{ font-style:normal; transition:transform .4s var(--ease); }
.work-card:hover .work-link i{ transform:translate(3px,-2px); }

/* ===== work — terminal / PowerShell windows ===== */
.term-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px; margin-top:56px; }
.work-stat{ margin-top:38px; text-align:center; font-family:var(--font-han); font-weight:700; font-size:clamp(22px,3.6vw,32px); color:#f6efe4; text-shadow:0 2px 20px rgba(0,0,0,.55), 0 1px 3px rgba(0,0,0,.45); }
.work-stat .accent{ font-weight:900;
  background:linear-gradient(100deg,#ffd98a 0%,#ffac5e 50%,#ff8a3a 100%);
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent;
  filter:drop-shadow(0 2px 12px rgba(0,0,0,.5)); }
.term-card{ display:block; border-radius:11px; overflow:hidden; text-decoration:none; border:1px solid rgba(120,140,180,.2);
  box-shadow:0 18px 44px rgba(24,14,7,.22); transition:transform .5s var(--ease), box-shadow .5s var(--ease), border-color .5s var(--ease); will-change:transform; }
.term-card:hover{ transform:translateY(-5px); border-color:rgba(255,180,110,.5); box-shadow:0 30px 66px rgba(24,14,7,.34); }
.term-bar{ display:flex; align-items:center; gap:10px; padding:9px 13px; background:#171c28; }
.term-bar .tdots{ display:flex; gap:6px; flex:none; }
.term-bar .tdots i{ width:10px; height:10px; border-radius:50%; background:rgba(255,255,255,.22); }
.term-bar .tdots i:nth-child(1){ background:#ff5f57; } .term-bar .tdots i:nth-child(2){ background:#febc2e; } .term-bar .tdots i:nth-child(3){ background:#28c840; }
.term-name{ font-family:var(--font-mono); font-size:11px; color:rgba(210,220,238,.5); letter-spacing:.01em; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.term-body{ position:relative; padding:16px 17px 18px; background:#0b1120; min-height:208px; font-family:var(--font-mono); font-size:12.5px; line-height:1.95; color:#c6d0e2; display:flex; flex-direction:column; }
.term-body::after{ content:""; position:absolute; left:17px; bottom:15px; width:8px; height:15px; background:#ffce8a; opacity:0; animation:tcaret 1.1s step-end infinite; }
.term-card:hover .term-body::after{ opacity:.9; }
.term-body .tl{ margin:0; }
.ps{ color:#ffce8a; } .cmd{ color:#6fb3ff; }
.term-body .meta{ margin-top:7px; font-size:11px; letter-spacing:.06em; text-transform:uppercase; color:rgba(198,208,226,.6); }
.led{ display:inline-block; width:7px; height:7px; border-radius:50%; background:#5a6678; margin-right:8px; vertical-align:middle; }
.led.live{ background:#3ad07a; box-shadow:0 0 8px #3ad07a; animation:pulse 2s ease-in-out infinite; }
.cat{ float:right; color:rgba(198,208,226,.4); }
.term-body .name{ font-family:var(--font-display); font-weight:600; font-size:17px; color:#fff; margin:9px 0 1px; }
.term-body .note{ color:#85935f; font-size:12px; line-height:1.7; flex:1; }
.term-body .out{ margin-top:11px; color:rgba(198,208,226,.85); }
.out .ok{ color:#3ad07a; } .out .url{ color:#6fb3ff; } .out .ar{ font-style:normal; color:#ffce8a; display:inline-block; transition:transform .4s var(--ease); }
.term-card:hover .out .ar{ transform:translate(3px,-2px); }
@keyframes tcaret{ 0%,100%{ opacity:.9 } 50%{ opacity:0 } }
@media (max-width:560px){ .term-grid{ grid-template-columns:1fr; } }

/* ============ MARQUEE ============ */
.marquee-band{ position:relative; padding:24px 0; border-top:1px solid rgba(255,255,255,.1); border-bottom:1px solid rgba(255,255,255,.1); background:rgba(12,8,4,.4); overflow:hidden; }
.marquee{ display:flex; width:max-content; }
.marquee-row{ display:flex; align-items:center; gap:24px; white-space:nowrap; animation:slide 44s linear infinite; font-family:var(--font-mono); font-weight:500; font-size:clamp(15px,2.2vw,21px); color:rgba(245,238,228,.66); padding-left:24px; text-transform:uppercase; letter-spacing:.04em; }
.marquee-row i{ color:var(--coral); font-style:normal; }
@keyframes slide{ to{ transform:translateX(-50%) } }

/* ============ CONTACT ============ */
.contact-wrap{ text-align:center; max-width:780px; margin:0 auto; }
.contact-title{ font-family:var(--font-han); font-weight:900; font-size:clamp(34px,6.6vw,74px); line-height:1.1; margin:22px 0 22px; color:#f6efe4; text-shadow:0 2px 24px rgba(0,0,0,.55); }
.contact .lede{ margin:0 auto 38px; }

/* ============ FOOTER ============ */
.footer{ position:relative; padding:54px clamp(20px,5vw,40px); border-top:1px solid rgba(255,255,255,.1); background:rgba(10,7,4,.55); }
.footer-wrap{ display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap; }
.footer-brand{ display:flex; align-items:center; gap:11px; font-family:var(--font-display); font-weight:600; letter-spacing:.14em; color:#f3ece0; }
.footer-dim{ font-family:var(--font-mono); font-size:12px; color:rgba(245,238,228,.5); letter-spacing:.04em; }

/* ============ REVEAL ============ */
.js .reveal{ opacity:0; transform:translateY(40px); filter:blur(8px); }
.js .reveal.in{ opacity:1; transform:none; filter:blur(0); transition:opacity .9s var(--ease), transform 1s var(--ease-2), filter .9s var(--ease); }

/* ============ RESPONSIVE ============ */
.br-d{ display:inline; }
@media (max-width:980px){
  .bento{ grid-template-columns:repeat(2,1fr); }
  .bento .cell:nth-child(n){ grid-column:span 1!important; }
  .work-grid{ grid-template-columns:repeat(2,1fr); }
  .stats{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:680px){
  .br-d{ display:none; }
  .nav-links{ position:fixed; inset:0; z-index:90; flex-direction:column; justify-content:center; gap:14px;
    background:rgba(255,245,233,.92); backdrop-filter:blur(28px); -webkit-backdrop-filter:blur(28px);
    opacity:0; visibility:hidden; transition:opacity .5s var(--ease), visibility .5s; }
  .nav-links.open{ opacity:1; visibility:visible; }
  .nav-links a:not(.nav-cta){ font-size:26px; font-family:var(--font-han); font-weight:700; color:var(--ink);
    opacity:0; transform:translateY(24px); transition:opacity .5s var(--ease-2), transform .6s var(--ease-2); }
  .nav-links.open a:not(.nav-cta){ opacity:1; transform:none; }
  .nav-links.open a:nth-child(1){ transition-delay:.12s; } .nav-links.open a:nth-child(2){ transition-delay:.18s; } .nav-links.open a:nth-child(3){ transition-delay:.24s; }
  .nav-cta{ margin-top:16px; font-size:16px; padding:12px 12px 12px 24px; opacity:0; transform:translateY(24px); transition:opacity .5s var(--ease-2) .3s, transform .6s var(--ease-2) .3s; }
  .nav-links.open .nav-cta{ opacity:1; transform:none; }
  .nav-cta .ico{ width:28px; height:28px; }
  .nav-toggle{ display:block; z-index:95; }
  .bento, .work-grid{ grid-template-columns:1fr; perspective:none; }
  .footer-wrap{ flex-direction:column; text-align:center; }
  .hero-hint{ display:none; }
}

/* ============ REDUCED MOTION ============ */
/* ===== preloader (cinematic loading screen → curtain reveal) ===== */
.preloader{ transition:opacity .45s ease; will-change:opacity; align-items:center; justify-content:center; overflow:hidden; }
.preloader.done{ opacity:0; }

/* — boot: laptop folds open → sun rises → cursor clicks → burst into site — */
.boot{ position:relative; z-index:3; width:min(360px,80vw); perspective:1300px; }
.lap{ position:relative; animation:bootIn .5s ease-out both; }
.lap-lid{ position:relative; z-index:2; transform-origin:50% 100%; transform:rotateX(-104deg); transition:transform .62s cubic-bezier(.2,.78,.2,1); }
.boot.open .lap-lid{ transform:rotateX(0deg); }
.lap-screen{ position:relative; aspect-ratio:16/10; border-radius:14px 14px 5px 5px; border:8px solid #241813; background:#120c08; overflow:hidden; box-shadow:0 18px 44px rgba(0,0,0,.55), inset 0 0 0 1px rgba(0,0,0,.3); }
.lap-cam{ position:absolute; top:2px; left:50%; transform:translateX(-50%); width:5px; height:5px; border-radius:50%; background:#3a2a1d; z-index:4; }
.screen-vid{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.lap-base{ position:relative; width:120%; left:-10%; height:18px; margin-top:-2px; border-radius:4px 4px 15px 15px; background:linear-gradient(#3a2a1d,#1d130c); box-shadow:0 16px 30px rgba(0,0,0,.5); z-index:3; }
.lap-pad{ position:absolute; top:0; left:50%; transform:translateX(-50%); width:76px; height:6px; border-radius:0 0 7px 7px; background:#160e09; }

/* cursor glides to the sun and clicks */
.cursor{ position:absolute; left:50%; top:40%; z-index:5; opacity:0; transform:translate(34px,42px); transition:transform .45s cubic-bezier(.3,.7,.2,1), opacity .25s ease; filter:drop-shadow(0 2px 4px rgba(0,0,0,.55)); pointer-events:none; }
.boot.point .cursor{ opacity:1; transform:translate(-1px,-1px); }
.boot.click .cursor{ transform:translate(-1px,-1px) scale(.82); }
.cursor-ring{ position:absolute; left:3px; top:3px; width:12px; height:12px; margin:-6px 0 0 -6px; border:2px solid #ffd98a; border-radius:50%; opacity:0; }
.boot.click .cursor-ring{ animation:clickRing .55s ease-out; }
@keyframes clickRing{ 0%{ opacity:.9; transform:scale(.3);} 100%{ opacity:0; transform:scale(3.4);} }

/* dark burst from the sun → fills screen with black → fades to reveal the real site (no blinding flash) */
.burst{ position:absolute; left:50%; top:48%; width:46px; height:46px; margin:-23px 0 0 -23px; border-radius:50%; z-index:8; opacity:0; pointer-events:none;
  background:radial-gradient(circle, #060403 0%, #060403 64%, rgba(6,4,3,0) 82%); transform:scale(0); }
.boot.burst-go ~ .burst, .burst.go{ animation:burst .55s cubic-bezier(.4,0,.25,1) forwards; }
@keyframes burst{ 0%{ opacity:1; transform:scale(0);} 60%{ opacity:1;} 100%{ opacity:1; transform:scale(64);} }

.pre-inner{ position:absolute; left:0; right:0; bottom:7vh; z-index:6; display:flex; flex-direction:column; align-items:center; gap:14px; animation:fadeUp .6s ease-out .3s both; }
.boot-logo{ font-family:var(--font-display); font-weight:600; font-size:clamp(22px,6vw,32px); letter-spacing:.005em; color:#f5ece0; text-shadow:0 2px 22px rgba(0,0,0,.6); }
.boot-logo .dom{ color:#ffce8a; font-weight:500; }
.sun-o{ position:relative; display:inline-block; width:.82em; height:.82em; margin:0 .015em; vertical-align:-.02em; border-radius:50%; overflow:hidden; background:#5a3a22; box-shadow:0 0 .4em rgba(255,150,60,.5); }
.sun-o .sun-horizon{ position:absolute; left:7%; right:7%; top:55%; height:.06em; background:#c98a52; border-radius:2px; z-index:3; }
.sun-o .sun{ position:absolute; left:50%; bottom:0; width:.66em; height:.66em; border-radius:50%; background:radial-gradient(circle at 50% 38%,#fffaf1,#ffd98c 42%,#f7a86b 72%,#e8703a 100%); box-shadow:0 0 .5em rgba(255,160,70,.85); transform:translate(-50%,14%); }
.pre-bar{ width:min(300px,70vw); height:3px; background:rgba(255,255,255,.16); border-radius:3px; overflow:hidden; }
.pre-bar i{ display:block; height:100%; width:0; background:linear-gradient(90deg,#ffd98a,#ff8a3a); border-radius:3px; transition:width .12s linear; box-shadow:0 0 10px rgba(255,140,50,.6); }
.pre-meta{ display:flex; justify-content:space-between; align-items:center; width:min(300px,70vw); font-family:var(--font-mono); font-size:10.5px; letter-spacing:.16em; color:rgba(245,238,228,.62); text-transform:uppercase; }

@keyframes bootIn{ from{ opacity:0; transform:translateY(12px) scale(.97);} to{ opacity:1; transform:none;} }
@keyframes fadeUp{ from{ opacity:0; transform:translateY(8px);} to{ opacity:1; transform:none;} }

@media (prefers-reduced-motion:reduce){
  *{ animation:none!important; }
  .js .reveal{ opacity:1!important; transform:none!important; filter:none!important; }
  .lap-lid{ transform:none!important; }
  .pre-inner{ opacity:1!important; transform:none!important; }
  html{ scroll-behavior:auto; }
}
