/* ============================================================
   PALAEMON SYSTEMS — Production stylesheet
   Direction: Refined Operator (dark default, paper alt)
   ============================================================ */

/* ----- Tokens (dark default) ----- */
:root, [data-theme="ink"] {
  --bg:        #0A0A0B;
  --surface:   #101012;
  --card:      #131316;
  --card-2:    #17171B;
  --ink:       #F5F5F7;
  --ink-2:     #D4D4D8;
  --soft:      #9CA3AF;
  --faint:     #6B7280;
  --rule:      rgba(255,255,255,.08);
  --rule-soft: rgba(255,255,255,.04);
  --rule-bold: rgba(255,255,255,.16);

  /* Status colors */
  --green: #34D399;
  --amber: #FBBF24;
  --pink:  #F472B6;
  --cyan:  #22D3EE;
  --red:   #F87171;

  /* Accent — indigo by default; ‑‑accent overridden by Tweaks */
  --accent-indigo: #7C9CFF;
  --accent-green:  #34D399;
  --accent-orange: #F59E5B;
  --accent: var(--accent-indigo);
  --accent-soft: rgba(124,156,255,.15);
  --accent-border: rgba(124,156,255,.30);

  --sans: 'Geist','Inter',system-ui,-apple-system,sans-serif;
  --mono: 'Geist Mono','JetBrains Mono',ui-monospace,'SF Mono',Menlo,monospace;

  --container: 1240px;
  --gutter: clamp(1.25rem, 3.5vw, 2rem);
}

[data-theme="paper"] {
  --bg:        #FAFAFA;
  --surface:   #F2F2F2;
  --card:      #FFFFFF;
  --card-2:    #F7F7F7;
  --ink:       #0A0A0A;
  --ink-2:     #1F2937;
  --soft:      #4B5563;
  --faint:     #9CA3AF;
  --rule:      rgba(0,0,0,.10);
  --rule-soft: rgba(0,0,0,.05);
  --rule-bold: rgba(0,0,0,.20);

  --green: #16A34A;
  --amber: #D97706;
  --pink:  #DB2777;
  --cyan:  #0891B2;
  --red:   #DC2626;

  --accent-indigo: #4F46E5;
  --accent-green:  #16A34A;
  --accent-orange: #C2410C;
  --accent: var(--accent-indigo);
  --accent-soft: rgba(79,70,229,.10);
  --accent-border: rgba(79,70,229,.30);
}

/* ----- Reset ----- */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-size:15px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  letter-spacing:-0.005em;
  transition:background-color .25s, color .25s;
}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
button{font:inherit;cursor:pointer;background:none;border:0;color:inherit;padding:0}
ul{list-style:none;padding:0;margin:0}
::selection{background:var(--accent);color:var(--bg)}

/* ----- Type primitives ----- */
.mono{font-family:var(--mono);font-size:12px;letter-spacing:0}
.label{font-family:var(--mono);font-size:11px;color:var(--faint);letter-spacing:.04em;text-transform:uppercase}
.dim{color:var(--faint)}
.soft{color:var(--soft)}
.txt-accent{color:var(--accent)}

/* ----- Layout ----- */
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 var(--gutter)}

.bg-grid{position:absolute;inset:0;
  background-image:linear-gradient(to right,var(--rule-soft) 1px,transparent 1px),
                    linear-gradient(to bottom,var(--rule-soft) 1px,transparent 1px);
  background-size:64px 64px;
  pointer-events:none;
  mask-image:linear-gradient(to bottom,rgba(0,0,0,.7),transparent 70%);
  -webkit-mask-image:linear-gradient(to bottom,rgba(0,0,0,.7),transparent 70%)}

/* ----- Header / Nav ----- */
.hdr{
  position:sticky;top:0;z-index:50;
  background:color-mix(in oklab, var(--bg) 80%, transparent);
  backdrop-filter:blur(12px) saturate(140%);
  -webkit-backdrop-filter:blur(12px) saturate(140%);
  border-bottom:1px solid var(--rule);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:56px;gap:1rem}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--mono);font-size:13.5px;font-weight:500;letter-spacing:0;color:var(--ink)}
.brand .mark{width:24px;height:24px;border-radius:6px;background:linear-gradient(135deg,var(--accent) 0%,color-mix(in oklab, var(--accent) 65%, #4F46E5) 100%);color:var(--bg);display:grid;place-items:center;font-family:var(--sans);font-weight:600;font-size:12px}
.brand .sep{color:var(--faint);margin:0 2px}
.brand .sub{color:var(--soft);font-weight:400}
.nav-links{display:flex;gap:2px;align-items:center;font-family:var(--mono);font-size:13px}
.nav-links a{color:var(--soft);padding:6px 10px;border-radius:6px;transition:all .15s;display:inline-flex;align-items:center;gap:6px}
.nav-links a:hover{color:var(--ink);background:var(--surface)}
.nav-links a.on{color:var(--ink)}
.nav-links a.on::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--accent)}
.nav-cta{background:var(--ink);color:var(--bg) !important;padding:7px 12px !important;border-radius:7px;margin-left:6px;font-family:var(--sans);font-size:13px;font-weight:500;white-space:nowrap}
.nav-cta:hover{background:var(--accent) !important;color:var(--bg) !important}
@media (max-width: 760px){
  .nav-links a:not(.nav-cta){display:none}
  .brand .sep,.brand .sub{display:none}
}

/* ----- Buttons ----- */
.btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:11px 18px;
  background:var(--ink);color:var(--bg);
  border:1px solid var(--ink);
  border-radius:9px;
  font-family:var(--sans);font-weight:500;font-size:14.5px;letter-spacing:-0.005em;
  transition:all .15s;
  white-space:nowrap;
}
.btn:hover{background:var(--accent);border-color:var(--accent);color:var(--bg)}
.btn--alt{background:transparent;color:var(--ink);border:1px solid var(--rule-bold)}
.btn--alt:hover{background:var(--card);color:var(--ink);border-color:var(--rule-bold)}
.btn .arrow{display:inline-block;transition:transform .15s}
.btn:hover .arrow{transform:translateX(2px)}

.tlink{
  font-family:var(--mono);font-size:13px;
  color:var(--ink);
  display:inline-flex;align-items:center;gap:6px;
  padding-bottom:2px;
  border-bottom:1px dashed var(--rule-bold);
  transition:all .15s;
}
.tlink:hover{color:var(--accent);border-color:var(--accent)}

/* ----- Status / pills ----- */
.pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:5px 10px 5px 8px;
  background:var(--accent-soft);color:var(--accent);
  border:1px solid var(--accent-border);
  border-radius:999px;
  font-family:var(--mono);font-size:11.5px;font-weight:500;letter-spacing:0;
}
.pill .dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 0 3px color-mix(in oklab, var(--accent) 30%, transparent);
  animation:ping 2.5s ease-out infinite;
}
@keyframes ping{
  0%   { box-shadow: 0 0 0 0 color-mix(in oklab, var(--accent) 50%, transparent); }
  70%  { box-shadow: 0 0 0 8px color-mix(in oklab, var(--accent) 0%, transparent); }
  100% { box-shadow: 0 0 0 0 color-mix(in oklab, var(--accent) 0%, transparent); }
}
@media (prefers-reduced-motion: reduce){
  .pill .dot{animation:none}
}

.tag{
  display:inline-flex;align-items:center;
  font-family:var(--mono);font-size:11px;font-weight:500;
  color:var(--soft);
  padding:3px 8px;
  background:var(--surface);
  border:1px solid var(--rule);
  border-radius:5px;
  letter-spacing:0;
}
.tag.live{color:var(--green);background:color-mix(in oklab, var(--green) 10%, transparent);border-color:color-mix(in oklab, var(--green) 25%, transparent)}
.tag.ai  {color:var(--pink); background:color-mix(in oklab, var(--pink)  10%, transparent);border-color:color-mix(in oklab, var(--pink)  25%, transparent)}
.tag.mob {color:var(--cyan); background:color-mix(in oklab, var(--cyan)  10%, transparent);border-color:color-mix(in oklab, var(--cyan)  25%, transparent)}
.tag.fs  {color:var(--accent);background:var(--accent-soft);border-color:var(--accent-border)}
.tag.feat{color:var(--accent);background:var(--accent-soft);border-color:var(--accent-border)}
.tag.in  {color:var(--amber);background:color-mix(in oklab, var(--amber) 10%, transparent);border-color:color-mix(in oklab, var(--amber) 25%, transparent)}

/* ----- Section header ----- */
.section{padding:clamp(3.5rem, 6vw, 5rem) 0;position:relative}
.sec-hd{
  display:flex;align-items:end;justify-content:space-between;
  gap:24px;
  margin-bottom:36px;padding-bottom:24px;
  border-bottom:1px solid var(--rule);
}
.sec-hd h2{
  font-family:var(--sans);font-weight:600;
  font-size:clamp(1.8rem, 3vw, 2.4rem);
  line-height:1.05;letter-spacing:-0.035em;
  margin:0;max-width:22ch;text-wrap:balance;
}
.sec-hd .lede{color:var(--soft);font-size:15px;line-height:1.55;margin:8px 0 0;max-width:52ch}
.sec-hd .meta{font-family:var(--mono);font-size:12px;color:var(--faint);white-space:nowrap}
.sec-hd .num{font-family:var(--mono);font-size:11.5px;color:var(--accent);letter-spacing:.04em;text-transform:uppercase;margin-bottom:8px;display:block}
.sec-hd .left{flex:1;min-width:0}
@media (max-width: 720px){
  .sec-hd{flex-direction:column;align-items:start;gap:0.4rem}
}

/* ----- Stack ticker ----- */
.ticker{padding:18px 0;border-bottom:1px solid var(--rule);background:var(--surface);overflow:hidden}
.ticker-row{display:flex;align-items:center;gap:24px;font-family:var(--mono);font-size:13px;color:var(--soft);white-space:nowrap}
.ticker-row .lbl{color:var(--faint);font-size:11px;text-transform:uppercase;letter-spacing:.04em;padding-right:18px;border-right:1px solid var(--rule);flex-shrink:0}
.ticker-row .items{display:flex;gap:20px;align-items:center;flex-wrap:wrap}
.ticker-row .items .item{color:var(--ink);font-family:var(--sans);font-weight:500;font-size:14px}
.ticker-row .items .sep{color:var(--faint)}
@media (max-width: 720px){
  .ticker-row{flex-direction:column;align-items:flex-start;gap:12px}
  .ticker-row .lbl{border-right:0;padding-right:0;padding-bottom:8px;border-bottom:1px solid var(--rule);width:100%}
}

/* ----- Contact ----- */
.contact{
  background:linear-gradient(180deg, var(--card) 0%, var(--surface) 100%);
  border:1px solid var(--rule);
  border-radius:18px;
  padding:clamp(2.5rem, 4.5vw, 3.5rem);
  display:grid;grid-template-columns:1.4fr 1fr;gap:40px;
  align-items:center;
  margin:0 0 4rem;
  position:relative;overflow:hidden;
}
.contact::before{
  content:'';position:absolute;top:-50%;right:-15%;
  width:600px;height:600px;
  background:radial-gradient(circle, color-mix(in oklab, var(--accent) 15%, transparent), transparent 60%);
  pointer-events:none;
}
.contact .num{font-family:var(--mono);font-size:11.5px;color:var(--accent);letter-spacing:.04em;text-transform:uppercase;margin-bottom:16px;display:block;position:relative;z-index:1}
.contact h2{
  font-family:var(--sans);font-weight:600;
  font-size:clamp(2rem, 3.5vw, 2.8rem);
  line-height:1.05;letter-spacing:-0.035em;
  margin:0 0 16px;max-width:16ch;
  position:relative;z-index:1;
}
.contact h2 .accent{color:var(--accent)}
.contact p{color:var(--soft);font-size:15px;line-height:1.55;margin:0 0 24px;max-width:46ch;position:relative;z-index:1}
.contact .actions{display:flex;gap:10px;flex-wrap:wrap;position:relative;z-index:1}
.contact-r{font-family:var(--mono);font-size:12px;color:var(--soft);position:relative;z-index:1}
.contact-r .row{display:flex;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px solid var(--rule)}
.contact-r .row:last-child{border-bottom:0}
.contact-r .row .v{color:var(--ink);font-weight:500}
.contact-r .row .v.ok{color:var(--green)}
@media (max-width: 720px){
  .contact{grid-template-columns:1fr}
  .contact-r{margin-top:4px}
}

/* ----- Footer ----- */
.ft{
  border-top:1px solid var(--rule);
  background:var(--surface);
  padding:48px 0 24px;
}
.ft-grid{
  display:grid;
  grid-template-columns:1.5fr 1fr 1fr 1fr;
  gap:32px;
}
.ft-grid h4{
  font-family:var(--mono);font-size:11px;
  letter-spacing:.04em;text-transform:uppercase;
  margin:0 0 12px;color:var(--faint);font-weight:500;
}
.ft-grid li{margin:0.4rem 0}
.ft-grid a{color:var(--soft);font-family:var(--mono);font-size:12.5px;transition:color .15s}
.ft-grid a:hover{color:var(--ink)}
.ft-grid p{color:var(--soft);font-size:13px;max-width:36ch;line-height:1.6;margin:0}
.ft-bottom{
  margin-top:36px;padding-top:18px;
  border-top:1px solid var(--rule);
  display:flex;justify-content:space-between;
  font-family:var(--mono);font-size:11.5px;color:var(--faint);
  letter-spacing:.04em;text-transform:uppercase;
}
@media (max-width: 800px){
  .ft-grid{grid-template-columns:1fr 1fr}
  .ft-bottom{flex-direction:column;gap:0.5rem}
}

/* ----- Card primitive ----- */
.card{background:var(--card);border:1px solid var(--rule);border-radius:12px}

/* ----- Project tag colors (matches direction B) ----- */
