/* =========================================================
   STYLE.CSS — ToolVault shared design system
   Every page (homepage + every tool page) links to this
   file. Change colors/fonts/header/footer here, it
   applies everywhere.
   ========================================================= */

:root{
  --cream:#FBF6EC;
  --indigo:#202A44;
  --marigold:#F2A93B;
  --teal:#1D7A74;
  --line:#E7DCC4;
  --card:#FFFFFF;
  --muted:#6B729A;
}
*{box-sizing:border-box; margin:0; padding:0;}
body{
  background:var(--cream);
  color:var(--indigo);
  font-family:'Work Sans',sans-serif;
}
.wrap{max-width:1160px; margin:0 auto; padding:0 32px;}
a{color:inherit;}

/* ---------- HEADER ---------- */
header{padding:20px 0; position:relative; border-bottom:1px solid var(--line);}
.headrow{display:flex; align-items:center; justify-content:space-between; gap:12px;}
.logo{font-family:'Fraunces',serif; font-weight:700; font-size:24px; color:var(--indigo); flex-shrink:0; text-decoration:none;}
.logo span{color:var(--marigold);}
nav{display:flex; gap:28px; font-size:14.5px; font-weight:500;}
nav a{color:var(--indigo); text-decoration:none; opacity:0.8; white-space:nowrap;}
.cta-pill{
  background:var(--indigo); color:var(--cream); font-size:14px; font-weight:600;
  padding:11px 22px; border-radius:100px; border:none; cursor:pointer; flex-shrink:0; white-space:nowrap;
  text-decoration:none; display:inline-block;
}
.menu-toggle{
  display:none; background:none; border:none; flex-direction:column; gap:5px; padding:6px; cursor:pointer; flex-shrink:0;
}
.menu-toggle span{width:22px; height:2px; background:var(--indigo); border-radius:2px; transition:transform .2s ease, opacity .2s ease;}

@media (max-width:760px){
  .cta-desktop{display:none;}
  .menu-toggle{display:flex;}
  header{z-index:100;}
  nav#mainNav{
    position:absolute; top:100%; left:0; right:0; background:var(--card);
    flex-direction:column; gap:0; padding:8px 0; margin:0 22px;
    border-radius:16px; box-shadow:0 12px 30px rgba(32,42,68,0.18);
    max-height:0; overflow:hidden; opacity:0; pointer-events:none;
    transition:max-height .25s ease, opacity .2s ease;
    z-index:100;
  }
  nav#mainNav.open{max-height:320px; opacity:1; pointer-events:auto;}
  nav#mainNav a{padding:14px 20px; opacity:1; border-bottom:1px solid var(--line); background:var(--card);}
  nav#mainNav a:last-child{border-bottom:none;}
  .menu-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
  .menu-toggle.open span:nth-child(2){opacity:0;}
  .menu-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
  .nav-backdrop{display:none; position:fixed; inset:0; background:rgba(32,42,68,0.25); z-index:90;}
  .nav-backdrop.open{display:block;}
}

/* ---------- FOOTER ---------- */
footer{padding:60px 0 36px; text-align:center; color:#8A8360; font-size:13px;}
footer .fname{font-family:'Fraunces',serif; color:var(--indigo); font-size:18px; margin-bottom:6px;}

/* ---------- HERO (homepage) ---------- */
.hero{position:relative; padding:56px 0 40px; text-align:center;}
.hero .kicker{
  display:inline-block; background:#FFF3DC; color:#946A0E; font-size:13px; font-weight:600;
  padding:6px 16px; border-radius:100px; margin-bottom:22px; max-width:100%;
}
h1{font-family:'Fraunces',serif; font-size:58px; line-height:1.06; font-weight:600; letter-spacing:-0.01em; max-width:680px; margin:0 auto;}
h1 .accent{color:var(--marigold); font-style:italic;}
.hero-sub{max-width:480px; margin:20px auto 0; font-size:16.5px; color:#4C567A; line-height:1.55; padding:0 8px;}

.search-row{
  max-width:520px; margin:32px auto 0; display:flex; background:var(--card);
  border-radius:100px; box-shadow:0 8px 24px rgba(32,42,68,0.08); padding:6px;
}
.search-row input{flex:1; min-width:0; border:none; outline:none; padding:14px 16px; font-size:15px; font-family:'Work Sans',sans-serif; background:transparent;}
.search-row button{background:var(--marigold); color:#3A2500; border:none; border-radius:100px; padding:0 22px; font-weight:600; font-size:14px; cursor:pointer; flex-shrink:0;}

/* ---------- CATEGORY TABS + TOOL GRID ---------- */
.folders{padding:56px 0 20px;}
.folder-tabs{
  display:flex; gap:10px; padding-left:8px; overflow-x:auto; -webkit-overflow-scrolling:touch; scrollbar-width:none;
}
.folder-tabs::-webkit-scrollbar{display:none;}
.folder-tab{
  background:#F2E9D4; padding:12px 22px 14px; border-radius:14px 14px 0 0; font-weight:600; font-size:14px;
  color:#7A6B45; cursor:pointer; white-space:nowrap; flex-shrink:0; border:none;
}
.folder-tab.active{background:var(--card); color:var(--indigo); box-shadow:0 -4px 14px rgba(32,42,68,0.06);}

.tool-panel{background:var(--card); border-radius:0 20px 20px 20px; padding:36px; box-shadow:0 4px 24px rgba(32,42,68,0.05);}
.tool-list{display:grid; grid-template-columns:repeat(3,1fr); gap:18px;}
.tool-item{border:1px solid var(--line); border-radius:16px; padding:22px; background:#FEFCF7; text-decoration:none; display:block; min-width:0; color:inherit; transition:transform .15s ease, box-shadow .15s ease;}
.tool-item:hover{transform:translateY(-2px); box-shadow:0 10px 24px rgba(32,42,68,0.08);}
.tool-icon{width:42px; height:42px; border-radius:12px; background:var(--marigold); margin-bottom:14px; display:flex; align-items:center; justify-content:center; font-size:18px; color:#3A2500; font-weight:700;}
.tool-item h3{font-family:'Fraunces',serif; font-size:17px; font-weight:600; margin-bottom:6px; display:flex; align-items:center; gap:8px;}
.tool-item p{font-size:13px; color:#6B729A; line-height:1.5;}
.badge{font-size:10px; font-weight:700; padding:2px 8px; border-radius:100px; text-transform:uppercase;}
.badge.trending{background:#FFE8CF; color:#946A0E;}
.badge.new{background:#DFF3EF; color:#1D7A74;}
.empty-state{padding:40px; text-align:center; color:var(--muted);}

/* ---------- TOOL PAGE LAYOUT (used by every tool page) ---------- */
.tool-page{padding:48px 0 80px;}
.tool-page-head{max-width:640px; margin:0 auto 32px; text-align:center;}
.tool-page-head h1{font-size:34px;}
.tool-page-head p{color:var(--muted); margin-top:10px; font-size:15px;}
.tool-card{
  max-width:640px; margin:0 auto; background:var(--card); border-radius:20px; padding:32px;
  box-shadow:0 4px 24px rgba(32,42,68,0.06); border:1px solid var(--line);
}
.field{margin-bottom:18px;}
.field label{display:block; font-size:13.5px; font-weight:600; margin-bottom:8px;}
.field input, .field select{
  width:100%; padding:12px 14px; border:1.5px solid var(--line); border-radius:10px; font-size:15px;
  font-family:'Work Sans',sans-serif; background:#FEFCF7; outline:none;
}
.field input:focus, .field select:focus{border-color:var(--marigold);}
.btn-primary{
  background:var(--marigold); color:#3A2500; border:none; border-radius:10px; padding:14px 24px;
  font-weight:700; font-size:15px; cursor:pointer; width:100%;
}
.btn-primary:hover{opacity:0.92;}
.result-box{
  margin-top:24px; padding:20px; background:#FFF8EB; border:1px solid #F2E1B8; border-radius:14px; display:none;
}
.result-box.show{display:block;}
.result-row{display:flex; justify-content:space-between; padding:8px 0; font-size:14.5px; border-bottom:1px dashed #E9D8AC;}
.result-row:last-child{border-bottom:none; font-weight:700; font-size:17px; padding-top:12px;}
.back-link{display:inline-block; margin-bottom:20px; font-size:14px; color:var(--muted); text-decoration:none;}
.back-link:hover{color:var(--indigo);}

/* ---------- RESPONSIVE ---------- */
@media (max-width:860px){
  .wrap{padding:0 22px;}
  h1{font-size:38px;}
  .tool-list{grid-template-columns:1fr 1fr;}
  .tool-panel{padding:24px;}
}
@media (max-width:600px){
  h1{font-size:30px;}
  .hero{padding:36px 0 28px;}
  .hero-sub{font-size:15px;}
  .search-row{margin:24px auto 0;}
  .search-row input{padding:12px 14px; font-size:14px;}
  .search-row button{padding:0 16px; font-size:13px;}
  .tool-list{grid-template-columns:1fr;}
  .tool-panel{padding:18px; border-radius:16px;}
  .folder-tab{padding:10px 16px 12px; font-size:13px;}
  footer{padding:44px 0 28px;}
  .tool-card{padding:22px;}
  .tool-page-head h1{font-size:26px;}
}
@media (max-width:380px){
  .logo{font-size:20px;}
  h1{font-size:26px;}
}
