/* ===========================================================================
   NexusFinLabs — Portafolio / Ecosistema
   navy #0A1A33 · gold #C9A14A · Frank Ruhl Libre + Montserrat · plano
   =========================================================================== */
:root{
  --navy:#0A1A33; --navy-800:#0D2040; --navy-700:#122948; --navy-600:#1B3556;
  --gold:#C9A14A; --gold-strong:#B68C36; --gold-soft:#E4CE96;
  --paper:#F6F3EC; --paper-2:#EFEBE0; --white:#fff;
  --ink:#0A1A33; --ink-soft:#45526A; --ink-mute:#6E7993; --line:#E3DFD3;
  --line-navy:rgba(255,255,255,.12);
  --on-navy:#F4F1EA; --on-navy-soft:#AEB8CB; --on-navy-mute:#76829B;
  --live:#4AC98A; --beta:#C9A14A; --soon:#76829B;
  --serif:"Frank Ruhl Libre",Georgia,serif; --sans:"Montserrat",system-ui,sans-serif;
  --maxw:1280px; --gutter:40px; --ease:cubic-bezier(.22,1,.36,1);
  --shadow-md:0 8px 24px rgba(10,26,51,.08),0 2px 6px rgba(10,26,51,.05);
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--paper);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{margin:0;font-weight:500}
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace}

/* Header */
.top{position:sticky;top:0;z-index:50;background:rgba(10,26,51,.92);backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid var(--line-navy)}
.top__in{display:flex;align-items:center;justify-content:space-between;height:68px}
.brand{display:inline-flex;align-items:center;gap:11px}
.brand__mark{width:28px;height:28px}
.brand__name{font-weight:700;font-size:17px;color:var(--on-navy);letter-spacing:-.01em}
.brand__name b{color:var(--gold)}
.top__link{font-size:14px;color:var(--on-navy-soft);transition:color .2s}
.top__link:hover{color:var(--gold)}

/* Hero */
.hero{background:var(--navy);color:var(--on-navy);padding:78px 0 64px;position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;top:-30%;right:-8%;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(201,161,74,.10),transparent 70%)}
.hero .wrap{position:relative;z-index:1}
.eyebrow{font-size:12.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin:0}
.hero__title{font-family:var(--serif);font-weight:500;font-size:54px;line-height:1.05;letter-spacing:-.02em;margin:14px 0 0;color:var(--on-navy);text-wrap:balance}
.hero__title em{font-style:normal;color:var(--gold)}
.hero__lead{font-size:18px;color:var(--on-navy-soft);margin:20px 0 0;max-width:60ch}
.hero__stats{display:flex;gap:42px;margin-top:36px;flex-wrap:wrap}
.hstat__n{font-family:var(--serif);font-size:38px;line-height:1;color:var(--on-navy)}
.hstat__n span{color:var(--gold)}
.hstat__l{font-size:13px;color:var(--on-navy-soft);margin-top:8px}

/* Controls */
.controls{position:sticky;top:68px;z-index:40;background:rgba(246,243,236,.9);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.controls__in{display:flex;align-items:center;justify-content:space-between;gap:20px;padding-block:16px;flex-wrap:wrap}
.chips{display:flex;gap:8px;flex-wrap:wrap}
.chip{font-size:13.5px;font-weight:600;color:var(--ink-soft);background:var(--white);border:1px solid var(--line);border-radius:100px;padding:8px 16px;cursor:pointer;transition:all .18s var(--ease)}
.chip:hover{border-color:var(--gold)}
.chip.is-active{background:var(--navy);color:var(--on-navy);border-color:var(--navy)}
.chip .c{opacity:.6;font-weight:500;margin-left:4px}
.tools{display:flex;align-items:center;gap:14px}
.search{display:flex;align-items:center;gap:8px;background:var(--white);border:1px solid var(--line);border-radius:9px;padding:8px 12px}
.search input{border:0;outline:0;background:transparent;font-family:inherit;font-size:14px;color:var(--ink);width:180px}
.search svg{width:15px;height:15px;color:var(--ink-mute)}
.viewtoggle{display:flex;background:var(--white);border:1px solid var(--line);border-radius:9px;overflow:hidden}
.viewtoggle button{border:0;background:transparent;padding:8px 12px;cursor:pointer;color:var(--ink-mute);display:grid;place-items:center}
.viewtoggle button svg{width:17px;height:17px}
.viewtoggle button.is-active{background:var(--navy);color:var(--on-navy)}

/* Section */
.section{padding:54px 0 90px}
.count{font-size:13px;color:var(--ink-mute);margin:0 0 22px}

/* Card grid */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.pcard{background:var(--white);border:1px solid var(--line);border-radius:14px;padding:24px;display:flex;flex-direction:column;min-height:200px;color:inherit;transition:border-color .22s var(--ease),transform .22s var(--ease),box-shadow .22s var(--ease)}
a.pcard{cursor:pointer}
a.pcard:hover{border-color:rgba(201,161,74,.55);transform:translateY(-3px);box-shadow:var(--shadow-md)}
.pcard--static{cursor:default}
.pcard__link--mute{color:var(--ink-mute)!important}
.pcard__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.status{display:inline-flex;align-items:center;gap:7px;font-size:11.5px;font-weight:600;letter-spacing:.02em;color:var(--ink-mute)}
.dot{width:8px;height:8px;border-radius:50%;flex:none}
.dot--live{background:var(--live);box-shadow:0 0 0 3px rgba(74,201,138,.16)}
.dot--beta{background:var(--beta);box-shadow:0 0 0 3px rgba(201,161,74,.16)}
.dot--soon{background:var(--soon)}
.pcard__cat{font-size:10.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-strong)}
.pcard__name{font-family:var(--serif);font-size:22px;color:var(--ink);letter-spacing:-.005em}
.pcard__domain{font-size:12.5px;color:var(--gold-strong);margin-top:4px;word-break:break-all}
.pcard__desc{font-size:14px;color:var(--ink-soft);line-height:1.55;margin:12px 0 0;flex:1}
.pcard__foot{display:flex;align-items:center;justify-content:space-between;margin-top:18px;gap:12px}
.stack{display:flex;flex-wrap:wrap;gap:6px}
.stack span{font-size:10.5px;font-weight:600;color:var(--ink-mute);background:var(--paper-2);border:1px solid var(--line);border-radius:100px;padding:3px 9px}
.pcard__link{font-size:13px;font-weight:600;color:var(--gold-strong);display:inline-flex;align-items:center;gap:5px;white-space:nowrap}
.pcard__link .ar{transition:transform .2s var(--ease)}
.pcard:hover .pcard__link .ar{transform:translateX(3px)}

/* Table (Caddyfile view) */
.tablewrap{display:none;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--white)}
.ptable{width:100%;border-collapse:collapse}
.ptable th{text-align:left;font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-mute);padding:14px 20px;background:var(--paper-2);border-bottom:1px solid var(--line)}
.ptable td{padding:13px 20px;font-size:14px;color:var(--ink-soft);border-bottom:1px solid var(--line);vertical-align:middle}
.ptable tr:last-child td{border-bottom:0}
.ptable tr:hover td{background:#FCFBF7}
.ptable .t-name{font-weight:600;color:var(--ink)}
.ptable .t-dom{font-family:ui-monospace,Menlo,monospace;font-size:12.5px;color:var(--gold-strong)}
.ptable .t-cat{font-size:12px}
.ptable .t-stack{font-size:12px;color:var(--ink-mute)}
.ptable .t-status{white-space:nowrap}
body.view-table .grid{display:none}
body.view-table .tablewrap{display:block}

/* Footer */
.foot{background:var(--navy-800);color:var(--on-navy-soft);padding:40px 0}
.foot__in{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:13px}
.foot a:hover{color:var(--gold)}

@media(max-width:1080px){:root{--gutter:28px}.grid{grid-template-columns:repeat(2,1fr)}.hero__title{font-size:44px}}
@media(max-width:720px){
  .grid{grid-template-columns:1fr}.hero__title{font-size:34px}.hero__stats{gap:28px}
  .controls__in{gap:12px}.search input{width:120px}
  .ptable .t-cat,.ptable th:nth-child(3),.ptable td:nth-child(3){display:none}
}
.hidden{display:none!important}
