:root{--bg: #f5f0e8;--surface: #ede8de;--ink: #1e1a14;--muted: #5e5650;--accent: #2e6b4a;--accent-2: #224f37;--accent-rgb: 46, 107, 74;--on-accent: #fbf9f4;--shadow: 0 24px 60px -30px rgba(40, 32, 20, .4);color-scheme:light;--good: #2f9e6f;--warn: #c06f1f;--bad: #c0392b;--bg-2: var(--surface);--surface-2: color-mix(in srgb, var(--ink) 6%, var(--surface));--muted-2: color-mix(in srgb, var(--muted) 72%, var(--bg));--line: color-mix(in srgb, var(--ink) 14%, transparent);--line-2: color-mix(in srgb, var(--ink) 24%, transparent);--glow: 0 14px 44px -16px rgba(var(--accent-rgb), .4);--radius: 16px;--maxw: 1080px;--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-display: "Space Grotesk", var(--font)}:root[data-palette=papel-tinta][data-mode=dark]{--bg: #191610;--surface: #231f18;--ink: #f0ebe0;--muted: #9a9288;--accent: #5a9e72;--accent-2: #6aad80;--accent-rgb: 90, 158, 114;--on-accent: #1a160f;--shadow: 0 24px 60px -28px rgba(0, 0, 0, .75);color-scheme:dark}:root[data-palette=sereno][data-mode=light]{--bg: #f5f0eb;--surface: #ede8e2;--ink: #1a1c22;--muted: #5b626d;--accent: #3a5f7d;--accent-2: #2c4f6a;--accent-rgb: 58, 95, 125;--on-accent: #f9fbfd;--shadow: 0 24px 60px -30px rgba(20, 28, 40, .4);color-scheme:light}:root[data-palette=sereno][data-mode=dark]{--bg: #151a24;--surface: #1d2333;--ink: #e8edf4;--muted: #8a95a8;--accent: #6da0c4;--accent-2: #82b0d1;--accent-rgb: 109, 160, 196;--on-accent: #121821;--shadow: 0 24px 60px -28px rgba(0, 0, 0, .7);color-scheme:dark}:root[data-palette=tinta-papel][data-mode=light]{--bg: #f7f5f0;--surface: #edebe6;--ink: #16140f;--muted: #5f5a54;--accent: #8b1a2e;--accent-2: #721626;--accent-rgb: 139, 26, 46;--on-accent: #fcf6f3;--shadow: 0 24px 60px -30px rgba(30, 20, 16, .4);color-scheme:light}:root[data-palette=tinta-papel][data-mode=dark]{--bg: #141210;--surface: #1e1c18;--ink: #f0ece4;--muted: #9b9490;--accent: #d07888;--accent-2: #dc8898;--accent-rgb: 208, 120, 136;--on-accent: #141210;--shadow: 0 24px 60px -28px rgba(0, 0, 0, .72);color-scheme:dark}*{box-sizing:border-box}body{margin:0;color:var(--ink);background:var(--bg);font-family:var(--font);-webkit-font-smoothing:antialiased;line-height:1.5}body:before{content:"";position:fixed;inset:0;z-index:-1;background:radial-gradient(55% 45% at 12% -5%,rgba(var(--accent-rgb),.07),transparent 70%),radial-gradient(45% 45% at 100% 105%,rgba(var(--accent-rgb),.05),transparent 70%);pointer-events:none}a{color:var(--accent);text-decoration:none}h1,h2,h3{font-family:var(--font-display)}.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}header.site{background:color-mix(in srgb,var(--bg) 78%,transparent);backdrop-filter:saturate(150%) blur(12px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:30}.nav{display:flex;align-items:center;justify-content:space-between;height:64px}.brand{display:flex;align-items:center;gap:11px;font-family:var(--font-display);font-weight:700;letter-spacing:-.02em;font-size:18px;color:var(--ink);text-decoration:none}.logo{width:36px;height:36px;border-radius:11px;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:grid;place-items:center;box-shadow:0 6px 20px -6px rgba(var(--accent-rgb),.6)}.logo svg{width:20px;height:20px;color:var(--on-accent)}.brand .t{color:var(--accent)}.brand small{display:block;font-family:var(--font);font-size:11px;font-weight:500;color:var(--muted)}.nav .privacy{font-size:12.5px;color:var(--accent);font-weight:700;display:inline-flex;align-items:center;gap:6px;background:rgba(var(--accent-rgb),.07);border:1px solid rgba(var(--accent-rgb),.35);padding:6px 12px;border-radius:999px}@media (max-width: 560px){.nav .privacy span{display:none}}.nav-right{position:relative;display:flex;align-items:center;gap:10px}.theme-btn{flex:none;width:38px;height:38px;display:grid;place-items:center;border-radius:11px;background:var(--surface);border:1px solid var(--line-2);color:var(--ink);cursor:pointer;transition:color .14s ease,border-color .14s ease}.theme-btn:hover{color:var(--accent);border-color:rgba(var(--accent-rgb),.5)}.theme-btn svg{width:18px;height:18px}.theme-pop{position:fixed;z-index:90;width:232px;padding:12px;background:var(--bg-2);border:1px solid var(--line-2);border-radius:14px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:8px}.theme-pop[hidden]{display:none}.theme-pop-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted-2)}.theme-swatches{display:flex;flex-direction:column;gap:5px}.theme-sw{display:flex;align-items:center;gap:11px;padding:7px 9px;border-radius:10px;background:none;border:1px solid transparent;color:var(--ink);font:inherit;font-size:13.5px;font-weight:600;cursor:pointer;text-align:left}.theme-sw:hover{background:var(--surface-2)}.theme-sw.active{border-color:rgba(var(--accent-rgb),.55);background:rgba(var(--accent-rgb),.08)}.theme-sw-chip{flex:none;width:24px;height:24px;border-radius:50%;border:1px solid var(--line-2)}.theme-modes{display:grid;grid-template-columns:1fr 1fr;gap:6px}.theme-mode{padding:9px;border-radius:10px;background:var(--surface);border:1px solid var(--line);color:var(--muted);font:inherit;font-size:13px;font-weight:600;cursor:pointer}.theme-mode:hover{color:var(--ink)}.theme-mode.active{color:var(--on-accent);background:linear-gradient(135deg,var(--accent),var(--accent-2));border-color:transparent}.theme-btn:focus-visible,.theme-sw:focus-visible,.theme-mode:focus-visible{outline:2px solid rgba(var(--accent-rgb),.85);outline-offset:2px}.hero{text-align:center;padding:56px 0 12px}.hero h1{font-size:clamp(30px,5vw,52px);font-weight:700;letter-spacing:-.03em;margin:0 0 14px;line-height:1.08}.hero h1 .g{background:linear-gradient(90deg,var(--accent),var(--accent-2));-webkit-background-clip:text;background-clip:text;color:transparent;filter:drop-shadow(0 2px 22px rgba(var(--accent-rgb),.4))}.hero p{color:var(--muted);font-size:clamp(15px,2vw,18px);max-width:640px;margin:0 auto}.cat{margin-top:40px}.cat:first-of-type{margin-top:30px}.cat-head{margin-bottom:16px}.cat-title{font-size:clamp(20px,3vw,26px);font-weight:700;letter-spacing:-.02em;margin:0}.cat-tag{color:var(--muted);font-size:14px;margin:4px 0 0}.tools-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:16px}.tool-card{position:relative;display:flex;align-items:flex-start;gap:16px;padding:22px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);color:var(--ink);text-decoration:none;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease}.tool-card:hover{transform:translateY(-3px);border-color:rgba(var(--accent-rgb),.45);box-shadow:var(--glow)}.tool-card .ic{flex:none;width:54px;height:54px;border-radius:14px;background:linear-gradient(135deg,rgba(var(--accent-rgb),.16),rgba(var(--accent-rgb),.06));border:1px solid rgba(var(--accent-rgb),.25);display:grid;place-items:center}.tool-card .ic svg{width:26px;height:26px;color:var(--accent)}.tool-card .name{font-family:var(--font-display);font-weight:700;font-size:18px;letter-spacing:-.01em;display:flex;align-items:center;gap:8px}.tool-card .tag{font-family:var(--font);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--accent);background:rgba(var(--accent-rgb),.12);padding:2px 8px;border-radius:999px}.tool-card .tag.soon-tag{color:var(--muted);background:color-mix(in srgb,var(--ink) 7%,transparent)}.tool-card .desc{margin-top:6px;font-size:13.5px;color:var(--muted);line-height:1.5}.tool-card .meta-badges{margin-top:10px;display:flex;flex-wrap:wrap;gap:6px}.tool-card .meta-badge{font-family:var(--font);font-size:11px;font-weight:600;letter-spacing:.02em;color:var(--muted);background:color-mix(in srgb,var(--ink) 6%,transparent);border:1px solid var(--line);padding:2px 8px;border-radius:999px}.tool-card .meta-badge.lang{color:var(--accent);background:rgba(var(--accent-rgb),.1);border-color:rgba(var(--accent-rgb),.22)}.tool-card.soon{cursor:default}.tool-card.soon:hover{transform:none;border-color:var(--line);box-shadow:none}.tool-card.soon .ic{background:color-mix(in srgb,var(--ink) 4%,transparent);border-color:var(--line)}.tool-card.soon .ic svg{color:var(--muted)}.tool-card.soon .name,.tool-card.soon .desc{opacity:.85}footer.site{border-top:1px solid var(--line);margin-top:64px;padding:30px 0 50px;color:var(--muted);font-size:13px;text-align:center}footer.site .foot-nav{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:8px 20px;margin-bottom:16px}footer.site .foot-nav a{color:var(--muted);font-weight:600;transition:color .12s}footer.site .foot-nav a:hover{color:var(--ink)}footer.site .foot-more{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:10px;margin-bottom:22px}footer.site .foot-more-label{width:100%;margin-bottom:4px;color:var(--muted-2);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.09em}footer.site .foot-more .pill{display:inline-flex;align-items:center;gap:7px;padding:7px 15px 7px 12px;border:1px solid var(--line);border-radius:999px;color:var(--ink);font-weight:600;font-size:13px;transition:border-color .14s,color .14s,transform .14s}footer.site .foot-more .pill svg{width:16px;height:16px;color:var(--accent);transition:transform .14s}footer.site .foot-more .pill:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}footer.site .foot-more .pill:hover svg{transform:scale(1.12) rotate(-6deg)}footer.site .ddev{display:inline-flex;align-items:baseline;font-family:var(--font-display);font-size:19px;letter-spacing:-.02em;line-height:1}footer.site .ddev .ddev-1{color:var(--ink);font-weight:300}footer.site .ddev .ddev-2{color:var(--accent);font-weight:700}footer.site .ddev:hover .ddev-2{color:var(--accent-2)}footer.site .foot-meta{margin-top:10px;color:var(--muted-2)}.legal{max-width:760px;padding-top:44px;padding-bottom:24px}.legal h1{font-size:clamp(28px,4vw,40px);letter-spacing:-.02em;margin:0 0 10px}.legal .legal-intro{color:var(--muted);font-size:16px;margin:0 0 8px}.legal section{margin-top:28px}.legal h2{font-size:18px;margin:0 0 8px}.legal p{color:var(--muted);line-height:1.7;margin:0 0 10px}.legal a{color:var(--accent)}.legal a:hover{color:var(--accent-2)}.continue-rail{margin-top:34px}.continue-title{font-size:clamp(18px,2.6vw,22px);font-weight:700;letter-spacing:-.02em;margin:0 0 14px}.continue-track{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(248px,1fr);gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:6px;scrollbar-width:thin}.continue-card{scroll-snap-align:start;display:flex;align-items:center;gap:13px;padding:14px 16px;background:var(--surface);border:1px solid var(--line);border-radius:14px;color:var(--ink);text-decoration:none;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease}.continue-card:hover{transform:translateY(-2px);border-color:rgba(var(--accent-rgb),.45);box-shadow:var(--glow)}.continue-ic{flex:none;width:42px;height:42px;border-radius:11px;background:linear-gradient(135deg,rgba(var(--accent-rgb),.16),rgba(var(--accent-rgb),.06));border:1px solid rgba(var(--accent-rgb),.25);display:grid;place-items:center}.continue-ic svg{width:21px;height:21px;color:var(--accent)}.continue-ct{min-width:0;flex:1}.continue-name{font-family:var(--font-display);font-weight:700;font-size:15px;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.continue-author{font-size:12.5px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.continue-bar{margin-top:8px;height:5px;border-radius:999px;background:color-mix(in srgb,var(--ink) 9%,transparent);overflow:hidden}.continue-bar span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--accent),var(--accent-2))}.continue-pct{margin-top:5px;font-size:11.5px;font-weight:600;color:var(--accent)}.hub-toolbar{margin-top:28px}.hub-bar{display:flex;gap:10px}.hub-search-input{flex:1 1 auto;min-width:0;height:46px;padding:0 14px;font:inherit;font-size:15px;color:var(--ink);background:var(--bg-2);border:1px solid var(--line-2);border-radius:12px;outline:none;transition:border-color .14s ease,box-shadow .14s ease}.hub-search-input::placeholder{color:var(--muted-2)}.hub-search-input:focus{border-color:rgba(var(--accent-rgb),.5);box-shadow:0 0 0 3px rgba(var(--accent-rgb),.12)}.hub-filter-toggle{flex:none;display:inline-flex;align-items:center;gap:8px;height:46px;padding:0 16px;font:inherit;font-size:14px;font-weight:700;color:var(--ink);background:var(--bg-2);border:1px solid var(--line-2);border-radius:12px;cursor:pointer}.hub-filter-toggle.has-filters{border-color:rgba(var(--accent-rgb),.5)}.hub-filter-ico{display:inline-grid;place-items:center}.hub-filter-ico svg{width:18px;height:18px;color:var(--accent)}.hub-filter-badge{min-width:19px;height:19px;padding:0 5px;border-radius:999px;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:var(--on-accent);font-size:11px;font-weight:800;display:inline-grid;place-items:center}.hub-filter-badge[hidden]{display:none}.hub-scrim{position:fixed;inset:0;z-index:40;background:#0000008c;backdrop-filter:blur(2px);opacity:0;visibility:hidden;transition:opacity .25s ease,visibility .25s ease}.hub-scrim.show{opacity:1;visibility:visible}.hub-panel{position:fixed;top:0;left:0;bottom:0;z-index:41;width:min(86vw,360px);display:flex;flex-direction:column;background:var(--bg-2);border-right:1px solid var(--line-2);box-shadow:0 24px 60px -10px #000000bf;transform:translate(-100%);visibility:hidden;transition:transform .28s cubic-bezier(.4,0,.2,1),visibility .28s ease;overscroll-behavior:contain}.hub-panel.open{transform:translate(0);visibility:visible}@media (prefers-reduced-motion: reduce){.hub-panel,.hub-scrim{transition:visibility 0s}}.hub-panel-head{flex:none;display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--line)}.hub-panel-head strong{font-family:var(--font-display);font-size:17px;font-weight:700}.hub-panel-close{font:inherit;font-size:17px;line-height:1;color:var(--muted);background:none;border:none;width:34px;height:34px;border-radius:9px;cursor:pointer}.hub-panel-close:hover{color:var(--ink);background:color-mix(in srgb,var(--ink) 7%,transparent)}.hub-panel-body{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:20px}.hub-sort-field{display:flex;flex-direction:column;gap:7px}.hub-sort{width:100%;height:44px;padding:0 14px;font:inherit;font-size:14px;color:var(--ink);background:var(--surface-2);border:1px solid var(--line-2);border-radius:11px;cursor:pointer;outline:none}.hub-sort:focus{border-color:rgba(var(--accent-rgb),.5)}.hub-filter-toggle:focus-visible,.hub-panel-close:focus-visible,.hub-apply:focus-visible,.hub-clear:focus-visible,.hub-clear-btn:focus-visible,.hub-sort:focus-visible,.chip:focus-visible{outline:2px solid rgba(var(--accent-rgb),.85);outline-offset:2px}.hub-filter-row{display:flex;flex-direction:column;gap:18px}.hub-group{display:flex;flex-direction:column;gap:9px}.hub-group-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted-2)}.hub-chips{display:flex;flex-wrap:wrap;gap:8px}.chip{font:inherit;font-size:13px;font-weight:600;color:var(--muted);background:color-mix(in srgb,var(--ink) 5%,transparent);border:1px solid var(--line);padding:8px 14px;border-radius:999px;cursor:pointer;transition:color .14s ease,background .14s ease,border-color .14s ease}.chip:hover{color:var(--ink);border-color:var(--line-2)}.chip.active{color:var(--on-accent);background:linear-gradient(135deg,var(--accent),var(--accent-2));border-color:transparent}.hub-meta{flex:none;display:flex;align-items:center;gap:12px;padding:14px 18px calc(14px + env(safe-area-inset-bottom,0px));border-top:1px solid var(--line);background:var(--bg-2)}.hub-count{display:none;font-size:13px;font-weight:600;color:var(--muted)}.hub-clear{font:inherit;font-size:14px;font-weight:600;color:var(--accent);background:none;border:none;padding:6px 4px;cursor:pointer}.hub-clear:hover{color:var(--accent-2);text-decoration:underline}.hub-apply{flex:1;height:46px;font:inherit;font-size:14px;font-weight:700;color:var(--on-accent);background:linear-gradient(135deg,var(--accent),var(--accent-2));border:none;border-radius:11px;cursor:pointer}.hub-apply:hover{filter:brightness(1.05)}html.hub-locked,body.hub-locked{overflow:hidden}.hub-empty{margin-top:30px;padding:44px 20px;text-align:center;background:var(--surface);border:1px dashed var(--line-2);border-radius:var(--radius)}.hub-empty-text{margin:0 0 14px;color:var(--muted);font-size:15px}.hub-clear-btn{font:inherit;font-size:14px;font-weight:700;color:var(--on-accent);background:linear-gradient(135deg,var(--accent),var(--accent-2));border:none;padding:10px 20px;border-radius:999px;cursor:pointer}.hub-clear-btn:hover{filter:brightness(1.05)}@media (min-width: 768px){.hub-toolbar{margin-top:34px;padding:16px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);display:flex;flex-direction:column;gap:14px}.hub-filter-toggle,.hub-scrim{display:none}.hub-panel{position:static;width:auto;transform:none;visibility:visible;transition:none;background:none;border:none;box-shadow:none;overscroll-behavior:auto;gap:14px}.hub-panel-head{display:none}.hub-panel-body{overflow:visible;padding:0;gap:14px}.hub-sort-field{flex-direction:row;align-items:center;gap:10px}.hub-sort{width:auto;min-width:200px}.hub-filter-row{flex-direction:row;flex-wrap:wrap;gap:16px 22px}.hub-meta{padding:12px 0 0;margin-top:2px;background:none;border-top:1px solid var(--line)}.hub-count{display:block;margin-right:auto}.hub-apply{display:none}html.hub-locked,body.hub-locked{overflow:auto}}.hidden{display:none!important}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.hub-toast{position:fixed;left:50%;bottom:1.25rem;transform:translate(-50%,1rem);z-index:80;max-width:min(92vw,32rem);padding:.8rem 1.1rem;border-radius:.7rem;background:#1b1813;color:#f5f0e8;border:1px solid rgb(255 255 255 / 14%);box-shadow:0 14px 40px #00000057;font-size:.92rem;line-height:1.45;text-align:center;opacity:0;visibility:hidden;transition:opacity .22s ease,transform .22s ease,visibility .22s}.hub-toast.show{opacity:1;visibility:visible;transform:translate(-50%)}@media (prefers-reduced-motion: reduce){.hub-toast{transition:opacity .22s ease;transform:translate(-50%)}}
