/* ============================================================
   Sun Forest Design System — colors & type tokens
   Aesthetic: modern technical / infrastructure
   Brand: deep navy blue + orange arc (from official logo)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&family=Noto+Sans+TC:wght@400;500;600;700;900&family=JetBrains+Mono:wght@400;500;600;700&display=swap');

:root {
  /* ---- Navy (PRIMARY brand color, sampled from official logo) ---- */
  --navy-50:  #EAF0F7;
  --navy-100: #C6D5E8;
  --navy-200: #8FAACE;
  --navy-300: #5C82B5;
  --navy-400: #305E9A;
  --navy-500: #1E467A;
  --navy-600: #163A66;
  --navy-700: #0F2F54;     /* PRIMARY — matches wordmark */
  --navy-800: #0A2240;
  --navy-900: #061528;

  /* ---- Orange (accent, sampled from logo arc) ---- */
  --orange-300: #F5A063;
  --orange-400: #EC8540;
  --orange-500: #E36918;     /* matches arc fill rgb(227,105,24) */
  --orange-600: #BC560F;
  --orange-700: #93420A;

  /* ---- Cyber (technical accent for dark mode) ---- */
  --cyber-300:  #79C8FF;
  --cyber-400:  #4FB3FF;
  --cyber-500:  #2A9DF4;
  --cyber-600:  #1B7FCC;

  /* ---- Light theme neutrals (cool blue-greys, paired w/ navy) ---- */
  --paper:      #F6F8FB;
  --paper-2:    #ECEFF4;
  --paper-3:    #DCE2EA;
  --ink-900:    #0B1220;
  --ink-700:    #1F2A3D;
  --ink-500:    #56627A;
  --ink-300:    #8892A6;
  --ink-100:    #C2CAD7;
  --white:      #FFFFFF;

  /* ---- Semantic tokens (LIGHT default) ---- */
  --bg-default:  var(--paper);
  --bg-alt:      var(--paper-2);
  --bg-fill-1:   var(--paper-2);
  --bg-fill-2:   var(--paper-3);
  --bg-card:     #FFFFFF;
  --bg-inverse:  var(--navy-700);
  --bg-grid:     rgba(11, 18, 32, 0.06);

  --fg-default:  var(--ink-900);
  --fg-body:     var(--ink-700);
  --fg-muted:    var(--ink-500);
  --fg-subtle:   var(--ink-300);
  --fg-inverse:  var(--paper);
  --fg-brand:    var(--navy-700);
  --fg-accent:   var(--orange-500);

  --border-subtle: rgba(11, 18, 32, 0.10);
  --border-strong: rgba(11, 18, 32, 0.22);
  --border-brand:  var(--navy-700);

  --shadow-sm: 0 1px 0 rgb(11 18 32 / 0.04), 0 1px 2px rgb(11 18 32 / 0.04);
  --shadow-md: 0 4px 12px -4px rgb(11 18 32 / 0.10);

  /* ---- Radius (sharp aesthetic) ---- */
  --radius-0: 0px;
  --radius-1: 2px;
  --radius-2: 4px;
  --radius-3: 8px;
  --radius-pill: 999px;

  /* ---- Spacing ---- */
  --space-1: 4px;  --space-2: 8px;  --space-3: 12px;
  --space-4: 16px; --space-5: 20px; --space-6: 24px;
  --space-7: 32px; --space-8: 40px; --space-9: 48px;
  --space-10: 64px; --space-11: 80px; --space-12: 96px;

  --container-max: 1320px;
  --container-pad: clamp(20px, 4vw, 40px);

  /* ---- Type ---- */
  --font-sans: 'Inter', 'Noto Sans TC', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-tc:   'Noto Sans TC', 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-mono: 'JetBrains Mono', ui-monospace, 'SF Mono', Menlo, monospace;

  --text-xs:12px; --text-sm:13px; --text-base:15px; --text-md:17px;
  --text-lg:20px; --text-xl:24px; --text-2xl:30px; --text-3xl:38px;
  --text-4xl:48px; --text-5xl:64px; --text-6xl:80px;

  --lh-tight:1.05; --lh-snug:1.2; --lh-normal:1.5; --lh-loose:1.65;
  --ls-tight:-0.02em; --ls-mono-wide:0.02em; --ls-wide:0.08em;

  --ease-out: cubic-bezier(0.22, 1, 0.36, 1);
  --dur-fast:120ms; --dur-base:180ms; --dur-slow:280ms;
}

/* ===== DARK THEME ============================================= */
[data-theme="dark"] {
  --bg-default: #060B16;
  --bg-alt:     #0A1322;
  --bg-fill-1:  #0F1B2E;
  --bg-fill-2:  #15263F;
  --bg-card:    #0A1322;
  --bg-inverse: var(--paper);
  --bg-grid:    rgba(255, 255, 255, 0.06);

  --fg-default: #ECEEF3;
  --fg-body:    #C5CAD5;
  --fg-muted:   #8892A6;
  --fg-subtle:  #56627A;
  --fg-inverse: var(--ink-900);
  --fg-brand:   var(--cyber-400);
  --fg-accent:  var(--orange-400);

  --border-subtle: rgba(255, 255, 255, 0.08);
  --border-strong: rgba(255, 255, 255, 0.18);
  --border-brand:  var(--cyber-400);

  --shadow-sm: 0 1px 0 rgb(0 0 0 / 0.30);
  --shadow-md: 0 4px 16px -4px rgb(0 0 0 / 0.50);
}

/* ===== BASE =================================================== */
*, *::before, *::after { box-sizing: border-box; }
html {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  color: var(--fg-body);
  background: var(--bg-default);
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
body { margin: 0; line-height: var(--lh-loose); }

/* ===== TYPE ROLES ============================================ */
h1,.h1{font-family:var(--font-sans);font-size:clamp(var(--text-4xl),5.5vw,var(--text-6xl));
  font-weight:700;line-height:var(--lh-tight);letter-spacing:var(--ls-tight);
  color:var(--fg-default);margin:0 0 var(--space-5);text-wrap:balance}
h2,.h2{font-size:clamp(var(--text-2xl),3.5vw,var(--text-4xl));font-weight:700;
  line-height:var(--lh-snug);letter-spacing:var(--ls-tight);color:var(--fg-default);
  margin:0 0 var(--space-4);text-wrap:balance}
h3,.h3{font-size:var(--text-xl);font-weight:600;line-height:var(--lh-snug);
  letter-spacing:var(--ls-tight);color:var(--fg-default);margin:0 0 var(--space-3)}
h4,.h4{font-size:var(--text-md);font-weight:600;line-height:var(--lh-snug);
  color:var(--fg-default);margin:0 0 var(--space-2)}
p{margin:0 0 var(--space-4);line-height:var(--lh-loose)}
.lede{font-size:var(--text-md);color:var(--fg-body);line-height:1.55;max-width:62ch}
.eyebrow{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:500;
  letter-spacing:var(--ls-mono-wide);color:var(--fg-muted);margin:0 0 var(--space-3);
  display:inline-flex;align-items:center;gap:var(--space-2)}
.eyebrow::before{content:"";width:24px;height:1px;background:currentColor;display:inline-block}
small,.caption{font-size:var(--text-sm);color:var(--fg-muted)}
code,kbd,pre{font-family:var(--font-mono);font-size:.92em}
:lang(zh),:lang(zh-Hant){font-family:var(--font-tc)}
a{color:inherit;text-decoration:none}

/* ===== BUTTONS =============================================== */
.btn{display:inline-flex;align-items:center;gap:var(--space-2);
  font-family:var(--font-sans);font-size:var(--text-sm);font-weight:600;line-height:1;
  padding:12px 18px;border-radius:var(--radius-2);border:1px solid transparent;
  cursor:pointer;transition:background var(--dur-base) var(--ease-out),
  color var(--dur-base) var(--ease-out),transform var(--dur-fast) var(--ease-out),
  border-color var(--dur-base) var(--ease-out);text-decoration:none}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--navy-700);color:#fff}
.btn-primary:hover{background:var(--navy-800)}
[data-theme="dark"] .btn-primary{background:var(--cyber-400);color:#060B16}
[data-theme="dark"] .btn-primary:hover{background:var(--cyber-300)}
.btn-secondary{background:transparent;color:var(--fg-default);border-color:var(--border-strong)}
.btn-secondary:hover{background:var(--bg-fill-1);border-color:var(--fg-default)}
.btn-accent{background:var(--orange-500);color:#fff}
.btn-accent:hover{background:var(--orange-600)}
.btn-ghost{background:transparent;color:var(--fg-default);padding:10px 12px}
.btn-ghost:hover{background:var(--bg-fill-1)}
.btn-sm{padding:9px 14px;font-size:var(--text-xs)}
.btn-lg{padding:16px 22px;font-size:var(--text-base)}

/* ===== UTILITIES ============================================ */
.container{max-width:var(--container-max);margin:0 auto;
  padding-left:var(--container-pad);padding-right:var(--container-pad)}
.section{padding-block:clamp(56px,8vw,112px)}
.section-alt{background:var(--bg-alt)}
.section-inverse{background:var(--bg-inverse);color:var(--fg-inverse)}
.section-inverse h1,.section-inverse h2,.section-inverse h3{color:var(--fg-inverse)}

.mono{font-family:var(--font-mono)}
.mono-label{font-family:var(--font-mono);font-size:var(--text-xs);
  letter-spacing:var(--ls-mono-wide);color:var(--fg-muted);text-transform:lowercase}

/* technical grid background */
.tech-grid{
  background-image:
    linear-gradient(var(--bg-grid) 1px, transparent 1px),
    linear-gradient(90deg, var(--bg-grid) 1px, transparent 1px);
  background-size: 32px 32px;
  background-position: -1px -1px;
}
.tech-dots{
  background-image: radial-gradient(var(--bg-grid) 1px, transparent 1px);
  background-size: 16px 16px;
}

/* corner brackets — technical accent */
.brackets{position:relative}
.brackets::before,.brackets::after{content:"";position:absolute;width:12px;height:12px;
  border:1.5px solid var(--fg-default);pointer-events:none}
.brackets::before{top:-1px;left:-1px;border-right:0;border-bottom:0}
.brackets::after{bottom:-1px;right:-1px;border-left:0;border-top:0}

/* ===== FORM INPUTS (modern, terminal-inflected) ============== */
.field{display:grid;gap:6px;margin-bottom:14px}
.field-label{font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;
  color:var(--fg-muted);text-transform:uppercase;display:flex;align-items:center;gap:8px}
.field-label::before{content:">";color:var(--orange-500);font-weight:700}
.field-input,.field-select,.field-textarea{
  width:100%;padding:12px 14px;font-size:14px;font-family:var(--font-sans);
  background:var(--bg-card);color:var(--fg-default);
  border:1px solid var(--border-subtle);border-left:2px solid var(--border-subtle);
  border-radius:0;outline:none;
  transition:border-color var(--dur-base) var(--ease-out), background var(--dur-base) var(--ease-out);
}
.field-input:hover,.field-select:hover,.field-textarea:hover{border-color:var(--border-strong)}
.field-input:focus,.field-select:focus,.field-textarea:focus{
  border-color:var(--navy-700);border-left:2px solid var(--orange-500);
  background:var(--white);
  box-shadow:0 0 0 3px rgba(15,47,84,0.08);
}
[data-theme="dark"] .field-input:focus,
[data-theme="dark"] .field-select:focus,
[data-theme="dark"] .field-textarea:focus{
  border-color:var(--cyber-400);border-left-color:var(--orange-400);
  background:var(--bg-fill-1);
  box-shadow:0 0 0 3px rgba(79,179,255,0.12);
}
.field-input.mono{font-family:var(--font-mono)}
.field-help{font-family:var(--font-mono);font-size:11px;color:var(--fg-subtle);letter-spacing:.02em}
.field-help.error{color:var(--orange-600)}

/* checkbox + radio (square, mono) */
.field-check{display:flex;align-items:flex-start;gap:10px;cursor:pointer;font-size:14px;color:var(--fg-body)}
.field-check input{appearance:none;-webkit-appearance:none;width:18px;height:18px;
  border:1.5px solid var(--border-strong);background:var(--bg-card);
  position:relative;cursor:pointer;flex-shrink:0;margin-top:1px;border-radius:0;
  transition:all var(--dur-base) var(--ease-out)}
.field-check input:hover{border-color:var(--navy-700)}
.field-check input:checked{background:var(--navy-700);border-color:var(--navy-700)}
.field-check input:checked::after{content:"";position:absolute;left:4px;top:1px;
  width:6px;height:10px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}
.field-check input[type="radio"]{border-radius:50%}
.field-check input[type="radio"]:checked{background:var(--bg-card);border:5px solid var(--navy-700)}
.field-check input[type="radio"]:checked::after{display:none}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}
