@import url('https://fonts.googleapis.com/css2?family=Kalam:wght@300;400;700&display=swap');

/* ── Design tokens ───────────────────────────────────────── */
:root{
  --primary:#f4a72a;
  --primary-dark:#d4850a;
  --primary-darker:#9a5e08;
  --primary-light:#fde8a8;
  --primary-lighter:#fef9ee;
  --text:#2c1810;
  --text-muted:#7a5c4a;
  --border:#2c1810;
  --border-soft:#c4a882;
  --bg:#faf3e0;
  --bg-soft:#f5ecd0;
  --card:#fdf6e3;
  --shadow-sm:2px 2px 0 #2c1810;
  --shadow:4px 4px 0 #2c1810;
  --shadow-lg:6px 6px 0 #2c1810;
}

/* ── Reset & base ────────────────────────────────────────── */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Kalam',cursive;
  font-size:1rem;
  color:var(--text);
  line-height:1.65;
  overflow-x:hidden;
  background-color:var(--bg);
  background-image:
    repeating-linear-gradient(0deg,  transparent,transparent 39px,rgba(139,100,60,.09) 39px,rgba(139,100,60,.09) 40px),
    repeating-linear-gradient(90deg, transparent,transparent 39px,rgba(139,100,60,.09) 39px,rgba(139,100,60,.09) 40px);
}
a{color:var(--primary-darker);text-decoration:none;transition:color .2s}
a:hover{color:var(--primary-dark)}
img{max-width:100%;display:block}
.container{max-width:1200px;margin:0 auto;padding:0 1.25rem}

/* ── Animations ──────────────────────────────────────────── */
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.8}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pop{0%{transform:scale(.9);opacity:0}60%{transform:scale(1.03)}100%{transform:scale(1);opacity:1}}
@keyframes slideRight{from{transform:translateX(-12px);opacity:0}to{transform:translateX(0);opacity:1}}
@keyframes glow{0%,100%{box-shadow:0 0 0 0 rgba(244,167,42,.4)}50%{box-shadow:0 0 0 12px rgba(244,167,42,0)}}

/* ── Header ──────────────────────────────────────────────── */
header.site-header{background:#2c1810;border-bottom:3px solid var(--primary);position:sticky;top:0;z-index:50;transition:box-shadow .25s}
header.site-header.scrolled{box-shadow:0 4px 0 #1a0f0a}
.nav{display:flex;align-items:center;justify-content:space-between;padding:1rem 0}

/* Logo */
.logo,.logo:hover{
  font-family:'Kalam',cursive;
  font-size:1.2rem;
  font-weight:700;
  color:#fff;
  display:flex;
  align-items:center;
  gap:.4rem;
  letter-spacing:.01em;
  transform:none !important;
}
.logo span{color:var(--primary)}
.logo-icon{flex-shrink:0}

/* Nav links */
.nav-links{display:flex;gap:1.75rem;list-style:none}
.nav-links a{
  font-family:'Kalam',cursive;
  font-size:0.95rem;
  font-weight:700;
  color:#d4bfa8;
  position:relative;
  padding:.25rem 0;
  transition:color .2s;
}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-4px;width:0;height:2px;background:var(--primary);border-radius:2px;transition:width .25s}
.nav-links a:hover{color:var(--primary)}
.nav-links a:hover::after{width:100%}
.menu-toggle{display:none;background:none;border:0;font-size:1rem;cursor:pointer;color:#fff}

/* ── Hero ────────────────────────────────────────────────── */
.hero{
  padding:5.5rem 0 5rem;
  text-align:center;
  position:relative;
  overflow:hidden;
  background-color:var(--bg);
  background-image:
    repeating-linear-gradient(0deg,  transparent,transparent 39px,rgba(139,100,60,.09) 39px,rgba(139,100,60,.09) 40px),
    repeating-linear-gradient(90deg, transparent,transparent 39px,rgba(139,100,60,.09) 39px,rgba(139,100,60,.09) 40px);
}
.hero::before,.hero::after{display:none}
.hero>.container{position:relative;z-index:1}
.hero h1{
  font-family:'Kalam',cursive;
  font-size:clamp(1.75rem,4vw,2.75rem);
  font-weight:700;
  letter-spacing:-.01em;
  line-height:1.1;
  margin-bottom:1.25rem;
  color:var(--text);
  animation:fadeUp .7s ease both;
}
.hero h1 span{color:var(--primary-darker);display:inline-block;position:relative}
.hero h1 span::after{content:"";position:absolute;left:0;right:0;bottom:.03em;height:.22em;background:var(--primary);opacity:.45;z-index:-1;border-radius:3px}
.hero p{
  font-family:'Kalam',cursive;
  font-size:1rem;
  font-weight:400;
  color:var(--text-muted);
  max-width:660px;
  margin:0 auto 1.75rem;
  animation:fadeUp .7s .12s ease both;
}
.hero .btn{animation:fadeUp .7s .24s ease both}
.hero-badge{
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  background:var(--primary);
  color:var(--text);
  padding:.45rem 1.1rem;
  border-radius:.4rem;
  font-family:'Kalam',cursive;
  font-size:1rem;
  font-weight:700;
  letter-spacing:.04em;
  margin-bottom:1.25rem;
  animation:fadeUp .7s ease both;
  border:2.5px solid var(--border);
  box-shadow:3px 3px 0 var(--border);
}
.hero-badge::before{display:none}

/* ── Buttons ─────────────────────────────────────────────── */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  background:var(--primary);
  color:var(--text);
  padding:.8rem 1.6rem;
  border-radius:.5rem;
  font-family:'Kalam',cursive;
  font-size:0.95rem;
  font-weight:700;
  letter-spacing:.03em;
  border:2.5px solid var(--border);
  box-shadow:4px 4px 0 var(--border);
  cursor:pointer;
  transition:transform .15s,box-shadow .15s,background .15s;
  position:relative;
  overflow:hidden;
}
.btn:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--border);background:var(--primary-dark);color:var(--text)}
.btn:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--border)}
.btn-outline{background:var(--card);color:var(--primary-darker);border:2.5px solid var(--border);box-shadow:3px 3px 0 var(--border)}
.btn-outline:hover{background:var(--primary-lighter);color:var(--primary-dark);box-shadow:5px 5px 0 var(--border)}

/* ── Sections ────────────────────────────────────────────── */
.section{
  padding:4.5rem 0;
  background-color:var(--bg-soft);
  background-image:
    repeating-linear-gradient(0deg,  transparent,transparent 39px,rgba(139,100,60,.07) 39px,rgba(139,100,60,.07) 40px),
    repeating-linear-gradient(90deg, transparent,transparent 39px,rgba(139,100,60,.07) 39px,rgba(139,100,60,.07) 40px);
}
.section-title{
  font-family:'Kalam',cursive;
  font-size:1.5rem;
  font-weight:700;
  text-align:center;
  margin-bottom:.5rem;
  letter-spacing:-.01em;
  color:var(--text);
}
.section-title::after{
  content:"";
  display:block;
  width:60px;
  height:4px;
  background:var(--primary);
  border-radius:2px;
  margin:.5rem auto 0;
  border:1.5px solid var(--border);
  box-shadow:2px 2px 0 var(--border);
}
.section-sub{
  font-family:'Kalam',cursive;
  font-size:0.9rem;
  font-weight:400;
  text-align:center;
  color:var(--text-muted);
  max-width:640px;
  margin:0 auto 2.5rem;
}

/* ── Tool grid ───────────────────────────────────────────── */
.tools-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.75rem}
.tool-card{
  background:var(--card);
  border:2.5px solid var(--border);
  box-shadow:5px 5px 0 var(--border);
  border-radius:.875rem;
  padding:1.75rem;
  transition:transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s;
  display:block;
  color:var(--text);
  position:relative;
  animation:fadeUp .6s ease both;
  opacity:0;
}
.tool-card::before{
  content:"";
  position:absolute;
  top:0;left:0;
  width:0;height:0;
  border-style:solid;
  border-width:16px 16px 0 0;
  border-color:var(--primary) transparent transparent transparent;
  border-radius:.875rem 0 0 0;
  z-index:1;
}
.tool-card:nth-child(1){animation-delay:.05s}
.tool-card:nth-child(2){animation-delay:.1s}
.tool-card:nth-child(3){animation-delay:.15s}
.tool-card:nth-child(4){animation-delay:.2s}
.tool-card:nth-child(5){animation-delay:.25s}
.tool-card:nth-child(6){animation-delay:.3s}
.tool-card:nth-child(7){animation-delay:.35s}
.tool-card:nth-child(8){animation-delay:.4s}
.tool-card:nth-child(9){animation-delay:.45s}
.tool-card:nth-child(10){animation-delay:.5s}
.tool-card:hover{transform:translate(-4px,-4px) rotate(-.8deg);box-shadow:9px 9px 0 var(--border);color:var(--text);background:var(--card)}
.tool-icon{
  width:56px;height:56px;
  border-radius:.5rem;
  background:var(--primary);
  color:var(--text);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:1.125rem;
  font-size:1rem;
  font-weight:700;
  border:2px solid var(--border);
  box-shadow:2px 2px 0 var(--border);
  transition:transform .3s cubic-bezier(.34,1.56,.64,1),background .2s;
}
.tool-card:hover .tool-icon{transform:scale(1.1) rotate(-6deg);background:var(--primary-dark);box-shadow:3px 3px 0 var(--border)}
.tool-card h3{font-family:'Kalam',cursive;font-size:0.9rem;font-weight:700;margin-bottom:.4rem;color:var(--text)}
.tool-card p{font-family:'Kalam',cursive;font-size:0.9rem;font-weight:400;color:var(--text-muted)}
.tool-card .arrow{position:absolute;right:1.5rem;top:1.75rem;color:var(--primary-darker);font-size:1.1rem;font-weight:700;opacity:0;transform:translateX(-8px);transition:all .3s}
.tool-card:hover .arrow{opacity:1;transform:translateX(0)}

/* ── Tool page ───────────────────────────────────────────── */
.tool-page{padding:2.5rem 0 4rem;animation:fadeIn .5s ease;background:var(--bg)}
.breadcrumb{font-family:'Kalam',cursive;font-size:1rem;color:var(--text-muted);margin-bottom:1.25rem;animation:slideRight .4s ease both}
.breadcrumb a{color:var(--text-muted)}
.breadcrumb a:hover{color:var(--primary-darker)}
.tool-page h1{font-family:'Kalam',cursive;font-size:clamp(1.4rem,3vw,2rem);font-weight:700;letter-spacing:-.01em;margin-bottom:1rem;animation:fadeUp .5s ease both;color:var(--text)}
.tool-page h1::first-letter{color:var(--primary-darker)}
.intro{font-family:'Kalam',cursive;font-size:0.95rem;font-weight:400;color:var(--text-muted);max-width:760px;margin-bottom:2rem;animation:fadeUp .5s .1s ease both}
.tool-box{
  background:var(--card);
  border:2.5px solid var(--border);
  box-shadow:var(--shadow);
  border-radius:1.25rem;
  padding:2rem;
  margin-bottom:2.5rem;
  animation:fadeUp .5s .2s ease both;
  position:relative;
  overflow:hidden;
}
.tool-box::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--primary)}

/* ── Form fields ─────────────────────────────────────────── */
.field{margin-bottom:1.25rem}
.field label{display:block;font-family:'Kalam',cursive;font-weight:700;margin-bottom:.5rem;font-size:0.9rem}
.field small{color:var(--text-muted);font-weight:400;font-size:.9rem}
textarea,input[type=text],input[type=password],input[type=number],input[type=url],select{
  width:100%;padding:.85rem 1rem;
  border:2px solid var(--border-soft);
  border-radius:.625rem;
  font-family:'Kalam',cursive;
  font-size:0.9rem;
  background:var(--card);
  color:var(--text);
  transition:border-color .2s,box-shadow .2s;
}
textarea{min-height:170px;resize:vertical;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.95rem;line-height:1.5}
textarea:focus,input:focus,select:focus{outline:0;border-color:var(--primary);box-shadow:0 0 0 4px rgba(244,167,42,.2)}
input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:6px;background:var(--border-soft);border-radius:3px;outline:none;padding:0}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;background:var(--primary);border-radius:50%;cursor:pointer;border:2px solid var(--border);box-shadow:2px 2px 0 var(--border);transition:transform .2s}
input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15)}
input[type=range]::-moz-range-thumb{width:22px;height:22px;background:var(--primary);border-radius:50%;cursor:pointer;border:2px solid var(--border)}
input[type=color]{cursor:pointer}
.controls{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.25rem}
.controls .btn{font-size:1rem;padding:.65rem 1.25rem}

/* ── Stats ───────────────────────────────────────────────── */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.75rem;margin-top:1.25rem}
.stat{
  background:var(--primary-lighter);
  border:2px solid var(--border);
  box-shadow:3px 3px 0 var(--border);
  border-radius:.75rem;
  padding:1rem;
  text-align:center;
  transition:transform .2s,box-shadow .2s;
}
.stat:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--border)}
.stat-value{font-family:'Kalam',cursive;font-size:1.1rem;font-weight:700;color:var(--primary-darker);display:block;line-height:1.1}
.stat-label{font-family:'Kalam',cursive;font-size:.85rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-weight:700;margin-top:.25rem;display:block}

/* ── Checkboxes ──────────────────────────────────────────── */
.checkbox-row{display:flex;flex-wrap:wrap;gap:1rem;margin:.75rem 0}
.checkbox-row label{display:flex;align-items:center;gap:.5rem;font-family:'Kalam',cursive;font-weight:700;font-size:1rem;cursor:pointer;padding:.5rem .75rem;border-radius:.5rem;transition:background .2s}
.checkbox-row label:hover{background:var(--primary-lighter)}
.checkbox-row input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary-darker);cursor:pointer}

/* ── Notice ──────────────────────────────────────────────── */
.notice{background:var(--primary-lighter);color:var(--primary-darker);padding:.75rem 1rem;border-radius:.625rem;font-family:'Kalam',cursive;font-size:1rem;margin-top:.75rem;display:none;border-left:3px solid var(--primary);animation:slideRight .25s ease}
.notice.show{display:block}
.notice.error{background:#fef2f2;color:#7a2008;border-left-color:var(--primary-darker)}

/* ── Guide / SEO content ─────────────────────────────────── */
.guide{margin:3rem 0}
.guide h2{font-family:'Kalam',cursive;font-size:1.25rem;font-weight:700;margin:2rem 0 .75rem;color:var(--text)}
.guide h3{font-family:'Kalam',cursive;font-size:1rem;font-weight:700;margin:1.25rem 0 .5rem;color:var(--text)}
.guide p{font-family:'Kalam',cursive;font-size:0.9rem;font-weight:400;color:var(--text-muted);margin-bottom:.875rem;max-width:760px}
.guide ul,.guide ol{margin:.5rem 0 1rem 1.25rem;color:var(--text-muted);font-family:'Kalam',cursive;font-size:0.9rem}
.guide li{margin-bottom:.4rem;font-weight:400}
.guide strong{color:var(--text);font-weight:700}
.guide-table{width:100%;border-collapse:collapse;margin:1rem 0;font-size:1rem}
.guide-table th{background:var(--text);color:#fff;padding:.6rem 1rem;text-align:left;font-family:'Kalam',cursive;font-weight:700;font-size:0.9rem}
.guide-table td{padding:.6rem 1rem;border-bottom:1.5px solid var(--border-soft);color:var(--text-muted);font-family:'Kalam',cursive;font-size:1rem}
.guide-table tr:last-child td{border-bottom:none}
.guide-table tr:nth-child(even) td{background:var(--bg-soft)}

/* ── FAQ ─────────────────────────────────────────────────── */
.faq h2,.related h2{font-family:'Kalam',cursive;font-size:1.25rem;font-weight:700;margin-bottom:1.5rem}
.faq-item{
  background:var(--card);
  border:2px solid var(--border);
  box-shadow:3px 3px 0 var(--border);
  border-radius:.75rem;
  margin-bottom:.75rem;
  overflow:hidden;
  transition:box-shadow .2s;
}
.faq-item:hover{box-shadow:5px 5px 0 var(--border)}
.faq-item summary{padding:1.125rem 1.375rem;font-family:'Kalam',cursive;font-weight:700;font-size:0.9rem;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;transition:color .2s}
.faq-item summary:hover{color:var(--primary-darker)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-size:1rem;color:var(--primary);font-weight:700;transition:transform .25s;line-height:1}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item[open] summary{color:var(--primary-darker)}
.faq-item p{padding:0 1.375rem 1.125rem;font-family:'Kalam',cursive;font-size:0.9rem;font-weight:400;color:var(--text-muted);animation:fadeIn .25s ease}

/* ── Related ─────────────────────────────────────────────── */
.related{margin-top:3.5rem}
.related-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}
.related-card{
  background:var(--card);
  border:2px solid var(--border);
  box-shadow:3px 3px 0 var(--border);
  border-radius:.75rem;
  padding:1.125rem 1.25rem;
  transition:transform .2s,box-shadow .2s,background .2s;
  color:var(--text);
  position:relative;
}
.related-card::before{content:"→";position:absolute;right:1rem;top:50%;transform:translate(8px,-50%);opacity:0;transition:all .25s;color:var(--primary-darker);font-size:1rem;font-weight:700}
.related-card:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--border);background:var(--primary-lighter);padding-right:2.5rem}
.related-card:hover::before{opacity:1;transform:translate(0,-50%)}
.related-card strong{font-family:'Kalam',cursive;font-weight:700;display:block;font-size:1rem;margin-bottom:.2rem}
.related-card span{font-family:'Kalam',cursive;font-size:.95rem;color:var(--text-muted)}

/* ── SEO section ─────────────────────────────────────────── */
.seo-section{
  background-color:var(--bg);
  background-image:
    repeating-linear-gradient(0deg,  transparent,transparent 39px,rgba(139,100,60,.09) 39px,rgba(139,100,60,.09) 40px),
    repeating-linear-gradient(90deg, transparent,transparent 39px,rgba(139,100,60,.09) 39px,rgba(139,100,60,.09) 40px);
  border-top:3px solid var(--border);
  padding:5rem 0;
  position:relative;
  overflow:hidden;
}
.seo-section::before{display:none}
.seo-section h2{
  font-family:'Kalam',cursive;
  font-size:1.5rem;
  font-weight:700;
  margin-bottom:1rem;
  color:var(--text);
  padding-left:.75rem;
  border-left:4px solid var(--primary);
}
.seo-section p{font-family:'Kalam',cursive;font-size:0.95rem;font-weight:400;color:var(--text-muted);margin-bottom:1rem;max-width:760px}
.seo-section ul{margin:1rem 0 1rem 1.25rem;color:var(--text-muted)}
.seo-section li{font-family:'Kalam',cursive;font-size:0.9rem;font-weight:400;margin-bottom:.6rem}
.seo-section strong{color:var(--text);font-weight:700}

/* ── Footer ──────────────────────────────────────────────── */
footer.site-footer{background:#2c1810;color:#c4a882;padding:3.5rem 0 1.75rem;margin-top:0;position:relative;overflow:hidden;border-top:4px solid var(--primary)}
footer.site-footer::before{display:none}
.footer-brand{
  display:flex;align-items:center;gap:.5rem;
  margin-bottom:.875rem;
  font-family:'Kalam',cursive;
  font-size:1.25rem;
  font-weight:700;
  color:#fff;
  text-decoration:none;
}
.footer-brand span{color:#fff}
.footer-brand em{color:var(--primary);font-style:normal}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:2.5rem;margin-bottom:2rem}
.footer-grid h4{font-family:'Kalam',cursive;color:var(--primary);font-size:0.9rem;margin-bottom:1rem;text-transform:uppercase;letter-spacing:.06em;font-weight:700}
.footer-grid ul{list-style:none}
.footer-grid li{margin-bottom:.5rem}
.footer-grid a{font-family:'Kalam',cursive;color:#c4a882;font-size:0.9rem;font-weight:400;transition:color .2s,padding-left .2s}
.footer-grid a:hover{color:var(--primary);padding-left:.25rem}
.footer-bottom{font-family:'Kalam',cursive;border-top:2px dashed #4a2e20;padding-top:1.75rem;text-align:center;color:#a08060;font-size:1rem;font-weight:400}
.footer-bottom a{color:#c4a882}
.footer-bottom a:hover{color:var(--primary)}

/* ── QR Output ───────────────────────────────────────────── */
.qr-output{display:flex;justify-content:center;align-items:center;padding:1.5rem;background:var(--primary-lighter);border-radius:.875rem;margin-top:1.25rem;min-height:200px;border:2.5px dashed var(--primary-light);transition:border-color .25s}
.qr-output canvas,.qr-output img{max-width:100%;height:auto;border-radius:.5rem;animation:pop .4s ease;box-shadow:var(--shadow);background:#fff}
.qr-empty{font-family:'Kalam',cursive;color:var(--text-muted);text-align:center;font-size:1rem}

/* ── Code output ─────────────────────────────────────────── */
.code-output{background:#2c1810;color:#f5ecd0;padding:1.125rem;border-radius:.625rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.875rem;overflow-x:auto;white-space:pre-wrap;word-break:break-all;max-height:300px;overflow-y:auto;line-height:1.5;border:2px solid var(--border)}

/* ── Dropzone ────────────────────────────────────────────── */
.dropzone{border:2.5px dashed var(--border-soft);border-radius:.875rem;padding:2.75rem 1.25rem;text-align:center;cursor:pointer;transition:all .25s;background:var(--primary-lighter);display:block;position:relative;overflow:hidden}
.dropzone:hover,.dropzone.drag{border-color:var(--primary);background:var(--primary-light);transform:scale(1.005)}
.dropzone.drag{animation:glow 1.2s infinite}
.dz-icon{font-size:3rem;line-height:1;margin-bottom:.75rem;display:inline-block;animation:float 3.2s ease-in-out infinite}
.dropzone:hover .dz-icon{animation-duration:1.5s}
.dropzone p{font-family:'Kalam',cursive;font-size:0.9rem;font-weight:400;color:var(--text-muted);margin-bottom:.4rem}
.dropzone p strong{font-weight:700;color:var(--text);font-size:0.9rem;display:block;margin-bottom:.25rem}
.dropzone .dz-hint{font-family:'Kalam',cursive;font-size:.95rem;color:var(--primary-darker);background:var(--card);display:inline-block;padding:.3rem .75rem;border-radius:999px;margin-top:.5rem;border:1.5px solid var(--border);font-weight:700}

/* ── Preview cards ───────────────────────────────────────── */
.preview-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem;margin-top:1.25rem}
.preview-card{
  background:var(--card);
  border:2px solid var(--border);
  box-shadow:3px 3px 0 var(--border);
  border-radius:.875rem;
  padding:1.125rem;
  text-align:center;
  transition:transform .2s,box-shadow .2s;
  animation:pop .4s ease;
}
.preview-card:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--border)}
.preview-card img{margin:0 auto .625rem;max-height:160px;border-radius:.5rem;box-shadow:var(--shadow-sm)}
.preview-card .label{font-family:'Kalam',cursive;font-size:.95rem;color:var(--text-muted);margin-bottom:.25rem;word-break:break-all}
.preview-card .size{font-family:'Kalam',cursive;font-weight:700;color:var(--primary-darker);font-size:0.9rem}
.preview-card .saved{font-family:'Kalam',cursive;color:var(--primary-dark);font-size:.9rem;font-weight:700;margin-left:.25rem}

/* ── Range row ───────────────────────────────────────────── */
.range-row{display:flex;align-items:center;gap:1rem}
.range-row input[type=range]{flex:1}
.range-row .val{font-family:'Kalam',cursive;font-weight:700;color:var(--primary-darker);min-width:54px;text-align:right;font-size:0.9rem;background:var(--primary-lighter);padding:.25rem .5rem;border-radius:.375rem;border:1.5px solid var(--border)}

/* ── Loading spinner ─────────────────────────────────────── */
.spinner{display:inline-block;width:18px;height:18px;border:2.5px solid rgba(244,167,42,.25);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle}

/* ── Strength bar ────────────────────────────────────────── */
.strength-bar{height:10px;background:var(--border-soft);border-radius:5px;overflow:hidden;position:relative;border:1.5px solid var(--border)}
.strength-bar>div{height:100%;border-radius:5px;transition:width .3s,background .3s;background:var(--primary)}

/* ── Reveal on scroll ────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:translateY(0)}

/* ── Blog index ──────────────────────────────────────────── */
.blog-page{padding:3rem 0 5rem;background:var(--bg)}
.blog-page h1{font-family:'Kalam',cursive;font-size:clamp(1.4rem,3vw,2rem);font-weight:700;margin-bottom:.5rem;animation:fadeUp .5s ease both}
.blog-page .page-sub{font-family:'Kalam',cursive;font-size:0.9rem;font-weight:400;color:var(--text-muted);margin-bottom:2.5rem;animation:fadeUp .5s .1s ease both}
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.75rem}
.blog-card{
  background:var(--card);
  border:2.5px solid var(--border);
  box-shadow:5px 5px 0 var(--border);
  border-radius:1rem;
  overflow:hidden;
  transition:transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s;
  display:flex;flex-direction:column;
  animation:fadeUp .6s ease both;
  opacity:0;
}
.blog-card:nth-child(1){animation-delay:.05s}.blog-card:nth-child(2){animation-delay:.1s}.blog-card:nth-child(3){animation-delay:.15s}.blog-card:nth-child(4){animation-delay:.2s}.blog-card:nth-child(5){animation-delay:.25s}
.blog-card:hover{transform:translate(-4px,-4px);box-shadow:9px 9px 0 var(--border)}
.blog-card-body{padding:1.5rem;flex:1;display:flex;flex-direction:column}
.blog-tag{display:inline-flex;align-items:center;gap:.3rem;background:var(--primary);color:var(--text);padding:.3rem .8rem;border-radius:.35rem;font-family:'Kalam',cursive;font-size:.9rem;font-weight:700;margin-bottom:.875rem;text-transform:uppercase;letter-spacing:.04em;border:1.5px solid var(--border);box-shadow:2px 2px 0 var(--border)}
.blog-card h2{font-family:'Kalam',cursive;font-size:1rem;font-weight:700;line-height:1.35;margin-bottom:.5rem;color:var(--text)}
.blog-card h2 a{color:inherit;transition:color .2s}
.blog-card h2 a:hover{color:var(--primary-darker)}
.blog-card p{font-family:'Kalam',cursive;font-size:0.9rem;font-weight:400;color:var(--text-muted);line-height:1.55;flex:1}
.blog-meta{display:flex;align-items:center;gap:1rem;margin-top:1rem;font-family:'Kalam',cursive;font-size:.95rem;color:var(--text-muted);padding-top:.875rem;border-top:1.5px solid var(--border-soft);font-weight:400}
.blog-meta span{display:flex;align-items:center;gap:.3rem}
.blog-read-link{display:inline-flex;align-items:center;gap:.35rem;font-family:'Kalam',cursive;color:var(--primary-darker);font-weight:700;font-size:1rem;margin-top:1rem;transition:gap .2s}
.blog-read-link:hover{gap:.6rem;color:var(--primary-dark)}
.coming-soon-card{opacity:.6;pointer-events:none}
.coming-soon-badge{background:var(--border-soft);color:var(--text-muted);padding:.25rem .7rem;border-radius:.35rem;font-family:'Kalam',cursive;font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;display:inline-block;margin-bottom:.875rem;border:1.5px solid var(--border)}

/* ── Blog post page ──────────────────────────────────────── */
.blog-post{padding:2.5rem 0 5rem;background:var(--bg)}
.blog-post-header{margin-bottom:2rem}
.blog-post-header .blog-tag{margin-bottom:1rem}
.blog-post-header h1{font-family:'Kalam',cursive;font-size:clamp(1.4rem,3vw,2rem);font-weight:700;line-height:1.15;margin-bottom:1rem;animation:fadeUp .5s ease both;color:var(--text)}
.blog-post-header .blog-meta{margin-top:0;border:none;padding:0;margin-bottom:1.5rem}
.blog-post-header .intro{font-family:'Kalam',cursive;font-size:0.95rem;font-weight:400;color:var(--text-muted);max-width:760px;border-left:4px solid var(--primary);padding-left:1rem;animation:fadeUp .5s .1s ease both}
.blog-content{max-width:760px}
.blog-content h2{font-family:'Kalam',cursive;font-size:1rem;font-weight:700;margin:2.25rem 0 .875rem;color:var(--text)}
.blog-content h3{font-family:'Kalam',cursive;font-size:1rem;font-weight:700;margin:1.5rem 0 .5rem;color:var(--text)}
.blog-content p{font-family:'Kalam',cursive;font-size:0.9rem;font-weight:400;color:var(--text-muted);line-height:1.75;margin-bottom:1rem}
.blog-content ul,.blog-content ol{margin:.5rem 0 1.25rem 1.5rem;font-family:'Kalam',cursive;font-size:0.9rem;color:var(--text-muted);line-height:1.7}
.blog-content li{margin-bottom:.5rem;font-weight:400}
.blog-content strong{color:var(--text);font-weight:700}
.blog-content a{color:var(--primary-darker);font-weight:700}
.blog-content a:hover{color:var(--primary-dark)}
.blog-content .btn{color:var(--text);font-weight:700}
.blog-content .btn:hover{color:var(--text)}
.blog-content .guide-table{margin:1.25rem 0 1.75rem}
.blog-cta{
  background:var(--primary-lighter);
  border:2px solid var(--border);
  box-shadow:4px 4px 0 var(--border);
  border-radius:1rem;
  padding:1.75rem 2rem;
  margin:2.5rem 0;
  display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;
}
.blog-cta p{font-family:'Kalam',cursive;margin:0;font-size:0.95rem;font-weight:700;color:var(--text);flex:1}
.blog-cta small{display:block;font-weight:400;color:var(--text-muted);font-size:1rem;margin-top:.2rem}

/* ── Mobile ──────────────────────────────────────────────── */
@media(max-width:768px){
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:#2c1810;flex-direction:column;padding:1rem;border-bottom:3px solid var(--primary);gap:.75rem;animation:fadeUp .25s ease}
  .nav-links.show{display:flex}
  .nav-links a{color:#d4bfa8}
  .menu-toggle{display:block}
  .hero{padding:3.5rem 0 3rem}
  .hero h1{font-size:1.25rem}
  .section{padding:2.5rem 0}
  .section-title{font-size:1.5rem}
  .tool-box{padding:1.25rem}
  .tools-grid{gap:1rem}
  .tool-card{padding:1.375rem}
  .tool-card::before{border-width:12px 12px 0 0}
}

@media(prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
}
