/* Calabi Tools — shared styles. Matches calabilabs.com tokens (dark + gold). */
:root{
  --bg:#0E0C09; --bg-deep:#060503; --surface:#171410; --surface-2:#1d1a14;
  --fg:#F2EDE2; --fg-soft:#C5BFB1; --muted:#8A8377; --muted-dim:#5C564B;
  --gold:#C9A961; --gold-light:#E5C57E; --green:#6A9F5D; --red:#B85A4A;
  --border:#2A2620; --border-soft:#1A1814;
  --font-display:'Fraunces',Georgia,serif; --font-body:'Inter Tight',system-ui,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
}
*{box-sizing:border-box}
*::selection{background:var(--gold);color:var(--bg-deep)}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font-body);color:var(--fg);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:var(--gold);text-decoration:none}
a:hover{color:var(--gold-light)}
.wrap{max-width:920px;margin:0 auto;padding:0 clamp(1.1rem,4vw,2rem)}

/* nav */
.t-nav{position:sticky;top:0;z-index:10;background:rgba(14,12,9,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--border-soft)}
.t-nav .wrap{display:flex;align-items:center;justify-content:space-between;height:60px}
.t-brand{display:flex;align-items:center;gap:.5rem;color:var(--fg)}
.t-brand .lab{font-family:var(--font-display);font-weight:300;font-size:1.05rem}
.t-brand .product{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
.t-nav__cta{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.04em;text-transform:uppercase;padding:.5rem .9rem;border:1px solid var(--gold);color:var(--bg-deep);background:var(--gold);border-radius:7px}
.t-nav__cta:hover{background:var(--gold-light);border-color:var(--gold-light);color:var(--bg-deep)}

/* header */
.t-head{padding:clamp(1.6rem,5vw,2.8rem) 0 1rem}
.breadcrumb{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);margin-bottom:.9rem}
.breadcrumb a{color:var(--muted)}.breadcrumb a:hover{color:var(--gold)}
h1{font-family:var(--font-display);font-weight:400;font-size:clamp(1.7rem,4vw,2.5rem);line-height:1.12;margin:0 0 .5rem}
.t-intro{color:var(--fg-soft);font-size:1.05rem;max-width:60ch;margin:0}
.t-badges{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:1rem}
.t-badge{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;color:var(--green);border:1px solid var(--border);background:var(--surface);padding:.3rem .6rem;border-radius:20px}

/* tool card */
.tool-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:clamp(1rem,3vw,1.5rem);margin:1.4rem 0}
.tool-opts{display:flex;flex-wrap:wrap;gap:.8rem 1.2rem;align-items:flex-end;margin-bottom:1rem}
.opt{display:flex;flex-direction:column;gap:.3rem}
.opt label{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.opt-check{flex-direction:row;align-items:center;gap:.45rem}
.opt-check label{text-transform:none;letter-spacing:0;font-size:.82rem;color:var(--fg-soft);font-family:var(--font-body)}
select,input[type=text],input[type=number]{font-family:var(--font-mono);font-size:.9rem;background:var(--bg-deep);color:var(--fg);border:1px solid var(--border);border-radius:8px;padding:.5rem .6rem}
input[type=number]{width:6rem}
input[type=checkbox]{width:1.05rem;height:1.05rem;accent-color:var(--gold)}
.io-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:680px){.io-grid{grid-template-columns:1fr}}
.io-col{display:flex;flex-direction:column;gap:.4rem}
.io-col label{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
textarea{font-family:var(--font-mono);font-size:.88rem;line-height:1.5;background:var(--bg-deep);color:var(--fg);border:1px solid var(--border);border-radius:10px;padding:.8rem;min-height:230px;resize:vertical;width:100%}
textarea[readonly]{color:var(--fg-soft)}
textarea.is-error,dl.is-error{border-color:var(--red)}
dl#tool-output{margin:0;min-height:230px;background:var(--bg-deep);border:1px solid var(--border);border-radius:10px;padding:.4rem .8rem;overflow:auto}
.kv{display:flex;justify-content:space-between;gap:1rem;padding:.55rem 0;border-bottom:1px solid var(--border-soft)}
.kv:last-child{border-bottom:0}
.kv dt{font-family:var(--font-mono);font-size:.74rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.kv dd{margin:0;font-family:var(--font-mono);font-size:.9rem;color:var(--fg);text-align:right;word-break:break-all}
.tool-actions{display:flex;gap:.6rem;margin-top:.8rem;flex-wrap:wrap}
.btn{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.04em;text-transform:uppercase;padding:.55rem 1rem;border-radius:8px;border:1px solid var(--border);background:var(--surface-2);color:var(--fg);cursor:pointer}
.btn:hover{border-color:var(--gold);color:var(--gold)}
.btn--primary{background:var(--gold);border-color:var(--gold);color:var(--bg-deep)}
.btn--primary:hover{background:var(--gold-light);color:var(--bg-deep)}
.tool-error{color:var(--red);font-family:var(--font-mono);font-size:.82rem;min-height:1.2em;margin-top:.5rem}

/* prose sections */
.t-section{margin:2.2rem 0}
.t-section h2{font-family:var(--font-display);font-weight:400;font-size:1.4rem;margin:0 0 .7rem}
.t-section ol,.t-section ul{color:var(--fg-soft);padding-left:1.2rem}
.t-section li{margin:.35rem 0}
.example{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--gold);border-radius:0 10px 10px 0;padding:.9rem 1.1rem;font-family:var(--font-mono);font-size:.85rem;color:var(--fg-soft);overflow:auto}
.related-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.7rem;list-style:none;padding:0}
.related-grid a{display:block;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:.8rem .9rem;color:var(--fg)}
.related-grid a:hover{border-color:var(--gold);color:var(--gold)}
.related-grid .cat{display:block;font-family:var(--font-mono);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:.2rem}

/* footer */
.t-foot{border-top:1px solid var(--border-soft);margin-top:3rem;padding:2rem 0;color:var(--muted);font-size:.85rem}
.t-foot .wrap{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.t-foot a{color:var(--fg-soft)}
