/* Niche of One Tools · Shared Stylesheet · /tools.css */
@import url('https://fonts.googleapis.com/css2?family=Stardos+Stencil:wght@400;700&family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500&display=swap');

:root{--bg:#F4F0E6;--card:#FFFFFF;--ink:#0F0F0F;--ink-dim:#4A4A4A;--ink-faint:#8A8A8A;--pink:#FF90E8;--pink-deep:#E574CC;--aqua:#78F0C8;--aqua-deep:#4ED4AC;--orange:#FF6414;--orange-deep:#D94B00;--green:#23A094;--yellow:#FFC900;--border:#0F0F0F;--border-w:2px;--stencil:'Stardos Stencil','Special Elite','Impact',sans-serif;--sans:'Plus Jakarta Sans',system-ui,sans-serif;--mono:'JetBrains Mono','Courier New',monospace}
*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}
body{font-family:var(--sans);font-size:15px;line-height:1.6;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased}
.container{max-width:880px;margin:0 auto;padding:32px 24px 80px}

/* Site header */
.site-header{border:var(--border-w) solid var(--border);background:var(--pink);padding:36px 28px 28px;margin-bottom:28px;box-shadow:6px 6px 0 var(--border);text-align:center}
.site-header .brand-name{font-family:var(--stencil);font-size:clamp(28px,5vw,44px);font-weight:400;letter-spacing:0.06em;line-height:1;text-transform:uppercase;margin-bottom:8px}
.site-header h1{font-family:var(--stencil);font-size:clamp(16px,2.5vw,22px);font-weight:400;letter-spacing:0.18em;line-height:1.1;margin-bottom:14px;text-transform:uppercase;padding-bottom:14px;border-bottom:var(--border-w) solid var(--ink);display:inline-block;padding-left:18px;padding-right:18px}

/* Cards */
.card{border:var(--border-w) solid var(--border);background:var(--card);margin-bottom:24px;box-shadow:4px 4px 0 var(--border)}
.card-header{border-bottom:var(--border-w) solid var(--border);padding:16px 24px;background:var(--bg);display:flex;align-items:center;justify-content:space-between;gap:12px}
.card-header h2{font-family:var(--stencil);font-size:16px;font-weight:400;text-transform:uppercase;letter-spacing:1.5px}
.card-body{padding:24px 28px;overflow:hidden;transition:max-height 0.3s ease,padding 0.3s ease,opacity 0.2s ease}
.intro{font-size:15px;line-height:1.7;color:var(--ink-dim);margin-bottom:16px}
.intro:last-child{margin-bottom:0}

/* Forms */
.field{margin-bottom:20px}
.field:last-child{margin-bottom:0}
.field label{display:block;font-family:var(--mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;color:var(--ink-dim)}
.field-help{font-size:12px;color:var(--ink-faint);margin-top:6px;line-height:1.4}
input[type="text"],input[type="number"],input[type="email"],input[type="date"],textarea,select{width:100%;border:var(--border-w) solid var(--border);background:var(--card);padding:12px 16px;font-family:var(--mono);font-size:14px;font-weight:500;color:var(--ink)}
input:focus,textarea:focus,select:focus{outline:none;background:#FFFCF5}
textarea{font-family:var(--sans);resize:vertical;min-height:80px}

/* Buttons */
.btn{display:inline-block;font-family:var(--sans);font-size:14px;font-weight:700;padding:12px 26px;text-decoration:none;border:var(--border-w) solid var(--border);background:var(--ink);color:var(--card);cursor:pointer;transition:all 0.1s;text-transform:uppercase;letter-spacing:0.8px;box-shadow:3px 3px 0 var(--border)}
.btn:hover{transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--border);background:var(--card);color:var(--ink)}
.btn:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--border)}
.btn-pink{background:var(--pink);color:var(--ink)}
.btn-pink:hover{background:var(--pink-deep);color:var(--ink)}
.btn-small{font-size:12px;padding:8px 16px}

/* Newsletter card */
.newsletter-card{border:var(--border-w) solid var(--border);background:var(--pink);margin-top:28px;margin-bottom:24px;box-shadow:4px 4px 0 var(--border)}
.newsletter-card-body{padding:28px;text-align:center}
.newsletter-card h3{font-family:var(--stencil);font-size:26px;font-weight:400;line-height:1.15;margin-bottom:12px;letter-spacing:0.02em;text-transform:uppercase}
.newsletter-card p{font-size:14px;color:var(--ink);margin-bottom:18px;max-width:460px;margin-left:auto;margin-right:auto;line-height:1.55}
.newsletter-card .btn{background:var(--ink);color:var(--card);font-size:14px;padding:12px 24px}
.newsletter-card .btn:hover{background:var(--card);color:var(--ink)}

/* Donation card */
.donate-card{border:var(--border-w) solid var(--border);background:var(--orange);margin-bottom:24px;box-shadow:4px 4px 0 var(--border)}
.donate-card-body{padding:24px 28px;display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.donate-icon{font-size:32px;flex-shrink:0}
.donate-text{flex:1;min-width:200px}
.donate-text h3{font-family:var(--stencil);font-size:20px;font-weight:400;margin-bottom:6px;color:#FFFFFF;text-transform:uppercase;letter-spacing:0.5px}
.donate-text p{font-size:13px;color:rgba(255,255,255,0.92);line-height:1.5}
.donate-card .btn{background:var(--ink);color:var(--card);flex-shrink:0}
.donate-card .btn:hover{background:var(--card);color:var(--ink)}

/* Modals */
.donate-overlay,.index-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.6);display:none;align-items:center;justify-content:center;z-index:1000;padding:24px}
.donate-overlay.show,.index-overlay.show{display:flex;animation:fadeIn 0.25s ease-out}
.index-overlay{background:rgba(0,0,0,0.7);z-index:1100}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

.donate-modal{background:var(--card);border:var(--border-w) solid var(--border);box-shadow:8px 8px 0 var(--orange);max-width:480px;width:100%}
.donate-modal-header{border-bottom:var(--border-w) solid var(--border);padding:22px 28px;background:var(--orange);text-align:center}
.donate-modal-header h3{font-family:var(--stencil);font-size:22px;font-weight:400;line-height:1.15;color:#FFFFFF;text-transform:uppercase;letter-spacing:0.5px}
.donate-modal-body{padding:28px;text-align:center}
.donate-modal-body p{font-size:14px;line-height:1.65;color:var(--ink-dim);margin-bottom:20px}
.donate-modal-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.donate-modal-actions .btn-secondary{background:var(--card);color:var(--ink);border:var(--border-w) solid var(--border)}
.donate-modal-actions .btn-secondary:hover{background:var(--bg);color:var(--ink)}

/* INDEX button */
.index-btn{position:fixed;top:20px;right:20px;z-index:900;width:64px;height:64px;background:var(--ink);color:var(--pink);border:var(--border-w) solid var(--pink);box-shadow:4px 4px 0 var(--pink);cursor:pointer;font-family:var(--stencil);font-size:13px;font-weight:400;text-transform:uppercase;letter-spacing:1.5px;display:flex;align-items:center;justify-content:center;transition:all 0.15s;padding:0}
.index-btn:hover{background:var(--pink);color:var(--ink);transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--ink)}
.index-btn:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--pink)}
@media (max-width:600px){.index-btn{top:14px;right:14px;width:56px;height:56px;font-size:12px}}

/* INDEX modal */
.index-modal{background:var(--bg);border:var(--border-w) solid var(--ink);box-shadow:10px 10px 0 var(--pink);max-width:420px;width:100%;max-height:90vh;overflow-y:auto}
.index-modal-header{border-bottom:var(--border-w) solid var(--ink);padding:20px 24px;background:var(--ink);display:flex;align-items:center;justify-content:space-between}
.index-modal-header h3{font-family:var(--stencil);font-size:22px;font-weight:400;color:var(--pink);text-transform:uppercase;letter-spacing:3px}
.index-close{background:transparent;border:var(--border-w) solid var(--pink);color:var(--pink);width:32px;height:32px;font-size:20px;font-weight:700;cursor:pointer;line-height:1;padding:0;transition:all 0.1s}
.index-close:hover{background:var(--pink);color:var(--ink)}
.index-list{list-style:none;padding:0;margin:0}
.index-item{border-bottom:1px dashed var(--ink)}
.index-item:last-child{border-bottom:none}
.index-item a{display:flex;align-items:center;gap:16px;padding:18px 24px;text-decoration:none;color:var(--ink);transition:all 0.12s}
.index-item a:hover{background:var(--pink);padding-left:32px}
.index-item-name{font-size:14px;font-weight:800;text-transform:uppercase;letter-spacing:1px;line-height:1.2;margin-bottom:2px}
.index-item-desc{font-family:var(--mono);font-size:10px;color:var(--ink-dim);text-transform:uppercase;letter-spacing:0.5px}
.index-item a:hover .index-item-desc{color:var(--ink)}
.index-modal-footer{border-top:var(--border-w) solid var(--ink);padding:14px 24px;background:var(--ink);text-align:center}
.index-modal-footer span{font-family:var(--stencil);font-size:12px;color:var(--pink);text-transform:uppercase;letter-spacing:2px}

/* Footer */
.footer-grid{border:var(--border-w) solid var(--border);background:var(--card);margin-top:40px;box-shadow:4px 4px 0 var(--border)}
.footer-header{border-bottom:var(--border-w) solid var(--border);padding:14px 24px;background:var(--bg);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:1.5px}
.footer-body{padding:24px}
.footer-links{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}
@media (max-width:600px){.footer-links{grid-template-columns:1fr}}
.footer-link{display:flex;flex-direction:column;gap:2px;padding:12px 16px;border:1px solid var(--ink);background:var(--bg);text-decoration:none;color:var(--ink);transition:background 0.1s}
.footer-link:hover{background:var(--pink)}
.footer-link-name{font-size:13px;font-weight:700}
.footer-link-url{font-family:var(--mono);font-size:11px;color:var(--ink-dim)}
.footer-meta{border-top:var(--border-w) dashed var(--ink);padding-top:16px;text-align:center;font-family:var(--mono);font-size:11px;color:var(--ink-faint);line-height:1.7}
.footer-meta strong{color:var(--ink)}
.footer-meta a{color:var(--ink);border-bottom:1px solid var(--ink);text-decoration:none}
.local-badge{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;padding:8px 14px;background:var(--ink);color:var(--card);border:var(--border-w) solid var(--ink);margin:16px auto 0}
.local-badge-wrap{text-align:center;margin-top:24px}
.affiliate-nudge{text-align:center;margin-top:16px;padding-top:16px;border-top:1px dashed var(--ink-faint);font-family:var(--mono);font-size:11px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:0.8px}
.affiliate-nudge a{color:var(--ink);border-bottom:1px solid var(--ink);text-decoration:none;font-weight:700}

/* Unsaved bar (for stateful tools) */
.unsaved-bar{position:fixed;top:0;left:0;right:0;background:#D32F2F;color:#FFFFFF;padding:14px 24px;display:none;align-items:center;justify-content:space-between;gap:16px;z-index:950;border-bottom:var(--border-w) solid var(--ink);box-shadow:0 4px 0 rgba(0,0,0,0.2)}
.unsaved-bar.show{display:flex}
.unsaved-bar-text{font-family:var(--mono);font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:0.5px}
.unsaved-bar button{background:var(--ink);color:var(--pink);border:var(--border-w) solid var(--pink);padding:8px 16px;font-family:var(--sans);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:0.8px;cursor:pointer;flex-shrink:0}
.unsaved-bar button:hover{background:var(--pink);color:var(--ink)}
body.has-unsaved{padding-top:56px}
body.has-unsaved .index-btn{top:76px}
@media (max-width:600px){body.has-unsaved .index-btn{top:110px}}
