
:root{
  --ink:#1f2f46;
  --ink-2:#304863;
  --kraft:#c79755;
  --kraft-dark:#926c36;
  --paper:#fffaf1;
  --card:#ffffff;
  --mist:#edf6f4;
  --teal:#20746f;
  --teal-dark:#155854;
  --line:#d8c9b3;
  --muted:#5e6a76;
  --shadow:0 16px 40px rgba(31,47,70,.12);
  --radius:18px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;color:var(--ink);background:linear-gradient(180deg,#fffaf1 0,#f6efe2 42%,#f8f9f7 100%);line-height:1.65;font-size:17px}
a{color:var(--teal-dark);text-decoration-thickness:2px;text-underline-offset:3px}
a:hover{color:#0f423f}
img,svg{max-width:100%;height:auto}.wrap{width:min(1180px,calc(100% - 36px));margin-inline:auto}.skip{position:absolute;left:-999px;top:0;background:#fff;padding:.8rem;z-index:99}.skip:focus{left:1rem;top:1rem}.topbar{background:#17283e;color:#fff;font-size:.92rem}.topbar .wrap{display:flex;justify-content:space-between;gap:1rem;padding:.38rem 0;flex-wrap:wrap}.topbar a{color:#fff}.site-header{position:sticky;top:0;z-index:50;background:rgba(255,250,241,.96);backdrop-filter:blur(12px);border-bottom:1px solid rgba(146,108,54,.26)}.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1.2rem;padding:.9rem 0}.brand{display:flex;align-items:center;gap:.7rem;text-decoration:none;color:var(--ink);font-weight:800;letter-spacing:-.02em}.brand img{width:50px;height:50px;flex:0 0 50px}.brand span{font-size:1.15rem;line-height:1.05}.main-nav{display:flex;gap:.38rem;flex-wrap:wrap;justify-content:flex-end}.main-nav a{text-decoration:none;color:var(--ink);font-weight:700;font-size:.94rem;padding:.55rem .7rem;border-radius:999px}.main-nav a:hover,.main-nav a[aria-current="page"]{background:var(--mist);color:var(--teal-dark)}.hero{padding:4rem 0 2.8rem}.hero-grid{display:grid;grid-template-columns:minmax(0,1.14fr) minmax(320px,.86fr);gap:2rem;align-items:center}.eyebrow{display:inline-flex;align-items:center;gap:.4rem;background:var(--mist);color:var(--teal-dark);font-weight:800;border:1px solid #b9dfd9;border-radius:999px;padding:.3rem .72rem;font-size:.88rem}.hero h1,.page-hero h1{font-size:clamp(2.1rem,5vw,4.75rem);line-height:.98;margin:.9rem 0 1rem;letter-spacing:-.06em}.hero p.lede,.page-hero .lede{font-size:clamp(1.08rem,2vw,1.32rem);color:#30415a;max-width:760px}.hero-actions{display:flex;gap:.8rem;flex-wrap:wrap;margin:1.4rem 0}.button{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;text-decoration:none;border-radius:999px;font-weight:800;padding:.82rem 1rem;border:2px solid var(--ink);background:var(--ink);color:#fff;box-shadow:0 8px 18px rgba(31,47,70,.16)}.button.secondary{background:#fff;color:var(--ink);border-color:var(--line);box-shadow:none}.button:hover{transform:translateY(-1px);color:#fff}.button.secondary:hover{color:var(--ink);background:var(--paper)}.hero-card{background:var(--card);border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow);padding:1.3rem}.hero-card h2{margin-top:0;font-size:1.35rem}.stack-list{display:grid;gap:.75rem;margin:1rem 0 0;padding:0;list-style:none}.stack-list li{display:grid;grid-template-columns:34px 1fr;gap:.65rem;align-items:start}.icon-dot{display:inline-grid;place-items:center;width:34px;height:34px;border-radius:12px;background:#f3dfbd;color:#6d4d20;font-weight:900}.section{padding:2.6rem 0}.section-title{display:flex;align-items:end;justify-content:space-between;gap:1rem;margin-bottom:1.2rem}.section-title h2{font-size:clamp(1.7rem,3vw,2.45rem);line-height:1.05;margin:0;letter-spacing:-.04em}.muted{color:var(--muted)}.grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:1.15rem;box-shadow:0 8px 24px rgba(31,47,70,.06)}.card h3{margin:.15rem 0 .45rem;font-size:1.18rem;line-height:1.16}.card p{margin:.45rem 0}.card .small{font-size:.92rem}.pill-row{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.8rem}.pill{display:inline-flex;align-items:center;border-radius:999px;padding:.24rem .6rem;background:#f3eadb;color:#62451e;font-size:.86rem;font-weight:800}.feature-band{background:#17283e;color:#fff;border-radius:28px;padding:1.5rem;box-shadow:var(--shadow)}.feature-band h2,.feature-band h3{color:#fff}.feature-band a{color:#d7fff9}.diagram{background:#fff;border:1px dashed #bb9d70;border-radius:20px;padding:1rem;overflow-x:auto}.flow{display:grid;grid-template-columns:repeat(5,minmax(145px,1fr));gap:.75rem;min-width:760px}.flow-step{background:#fffaf1;border:1px solid #e6d5ba;border-radius:16px;padding:.8rem}.flow-step strong{display:block;color:var(--teal-dark);font-size:.94rem;margin-bottom:.25rem}.page-hero{padding:2.8rem 0 1.8rem}.breadcrumb{font-size:.93rem;color:var(--muted);margin-bottom:.8rem}.breadcrumb a{text-decoration:none}.content-wrap{display:grid;grid-template-columns:minmax(0,760px) 320px;gap:2rem;align-items:start}.content{background:#fff;border:1px solid var(--line);border-radius:24px;padding:1.5rem;box-shadow:0 10px 26px rgba(31,47,70,.05)}.content h2{font-size:1.65rem;line-height:1.12;margin:1.8rem 0 .7rem;letter-spacing:-.03em}.content h3{margin-top:1.25rem;line-height:1.15}.content h2:first-child{margin-top:0}.content table{width:100%;border-collapse:collapse;margin:1rem 0;border-radius:14px;overflow:hidden}.content th,.content td{border:1px solid #e4d6c0;padding:.68rem;text-align:left;vertical-align:top}.content th{background:#f3eadb}.content tr:nth-child(even) td{background:#fffdf8}.content blockquote{border-left:5px solid var(--teal);padding:.8rem 1rem;margin:1rem 0;background:#eef8f6;border-radius:0 14px 14px 0}.sidebar{position:sticky;top:96px;display:grid;gap:1rem}.sidebar-box{background:#fff;border:1px solid var(--line);border-radius:20px;padding:1rem;box-shadow:0 8px 22px rgba(31,47,70,.05)}.sidebar-box h3{margin-top:0}.toc{list-style:none;padding:0;margin:0;display:grid;gap:.4rem}.toc a{text-decoration:none}.checklist{padding-left:1.2rem}.checklist li{margin:.38rem 0}.notice{border:1px solid #b9dfd9;background:#effbf8;border-radius:16px;padding:1rem}.warning{border:1px solid #e3c58a;background:#fff6e4;border-radius:16px;padding:1rem}.tool-panel{background:#fff;border:1px solid var(--line);border-radius:24px;padding:1.2rem;box-shadow:var(--shadow);margin:1rem 0}.tool-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.tool-grid label{display:grid;gap:.3rem;font-weight:800}.tool-grid input,.tool-grid select,.tool-grid textarea{width:100%;font:inherit;border:1px solid #cdbb9e;border-radius:12px;padding:.72rem;background:#fffdf8;color:var(--ink)}.result{background:#effbf8;border:1px solid #b9dfd9;border-radius:16px;padding:1rem;margin-top:1rem;font-weight:700}.site-footer{background:#17283e;color:#f8f1e8;margin-top:3rem;padding:2.5rem 0 1.2rem}.footer-grid{display:grid;grid-template-columns:1.1fr repeat(3,minmax(160px,1fr));gap:1.2rem}.site-footer a{color:#e8fff9}.site-footer h2,.site-footer h3{color:#fff;margin-top:0}.footer-bottom{border-top:1px solid rgba(255,255,255,.18);margin-top:1.5rem;padding-top:1rem;color:#d0d7df;font-size:.92rem}.kbd{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;background:#f3eadb;border:1px solid #dac7a6;border-radius:7px;padding:.08rem .35rem}.link-list{list-style:none;margin:0;padding:0;display:grid;gap:.42rem}.article-list{display:grid;gap:.75rem}.article-list a{font-weight:800}.visually-hidden{position:absolute!important;height:1px;width:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);white-space:nowrap}@media (max-width:900px){.hero-grid,.content-wrap{grid-template-columns:1fr}.sidebar{position:static}.grid,.grid.two,.footer-grid,.tool-grid{grid-template-columns:1fr}.hero{padding-top:2.6rem}.header-inner{align-items:flex-start;flex-direction:column}.main-nav{justify-content:flex-start}.brand img{width:44px;height:44px}.content{padding:1rem}.topbar .wrap{font-size:.86rem}}@media print{.site-header,.topbar,.site-footer,.sidebar,.hero-actions{display:none}.content-wrap{display:block}.content{box-shadow:none;border:0}.wrap{width:100%}body{background:#fff;color:#000}}
