

@font-face{font-family:'Roboto';font-style:normal;font-weight:400;font-display:swap;src:url('./fonts/roboto-400-normal.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Roboto';font-style:normal;font-weight:500;font-display:swap;src:url('./fonts/roboto-500-normal.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Roboto';font-style:normal;font-weight:700;font-display:swap;src:url('./fonts/roboto-700-normal.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}

:root{
  --bg:#ffffff;
  --surface:#ffffff;
  --tint:#f8f9fa;
  --tint-blue:#e8f0fe;
  --border:#dadce0;
  --ink:#202124;
  --ink-2:#5f6368;
  --blue:#1a73e8;
  --blue-hover:#1765cc;
  --star:#f9ab00;
  --shadow:0 1px 2px rgba(60,64,67,.3),0 1px 3px 1px rgba(60,64,67,.15);
  --shadow-2:0 1px 3px rgba(60,64,67,.3),0 4px 8px 3px rgba(60,64,67,.15);
  --radius:8px;
  --maxw:1160px;
}

*{box-sizing:border-box}
html{overflow-x:hidden;scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Roboto',Arial,Helvetica,sans-serif;
  font-size:16px;
  line-height:1.6;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4,h5{margin:0 0 .5em;font-weight:500;color:var(--ink);line-height:1.25}
p{margin:0 0 1em}

.skip{position:absolute;left:-999px;top:0;background:var(--blue);color:#fff;padding:.6rem 1rem;border-radius:0 0 8px 0;z-index:200}
.skip:focus{left:0}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.45em;
  font-family:inherit;font-size:.95rem;font-weight:500;
  padding:.62em 1.5em;border-radius:999px;border:1px solid transparent;
  cursor:pointer;transition:background .15s,box-shadow .15s,border-color .15s;
  text-decoration:none;white-space:nowrap;
}
.btn:hover{text-decoration:none}
.btn-primary{background:var(--blue);color:#fff}
.btn-primary:hover{background:var(--blue-hover);box-shadow:var(--shadow)}
.btn-ghost{background:#fff;color:var(--blue);border-color:var(--border)}
.btn-ghost:hover{background:var(--tint-blue);border-color:#c6dafc}
.btn-text{background:none;color:var(--blue);padding:.5em .9em}
.btn-text:hover{background:var(--tint-blue)}

.appbar{
  position:sticky;top:0;z-index:100;
  background:#fff;border-bottom:1px solid var(--border);
}
.appbar-in{
  max-width:var(--maxw);margin:0 auto;padding:0 24px;
  height:64px;display:flex;align-items:center;gap:1.5rem;
}
.brand{display:inline-flex;align-items:center;gap:.6rem;font-weight:500;font-size:1.25rem;color:var(--ink);text-decoration:none}
.brand:hover{text-decoration:none}
.brand svg{width:32px;height:32px;border-radius:8px;flex:none}
.brand b{font-weight:700}

.nav{margin-left:auto;display:flex;align-items:center;gap:.35rem}
.nav a.navlink{
  color:var(--ink-2);font-size:.95rem;font-weight:500;
  padding:.5rem .85rem;border-radius:999px;
}
.nav a.navlink:hover{background:var(--tint);color:var(--ink);text-decoration:none}
.nav .btn{margin-left:.5rem}

.hamburger{
  display:none;margin-left:auto;background:none;border:none;cursor:pointer;
  width:44px;height:44px;border-radius:50%;color:var(--ink);
  align-items:center;justify-content:center;
}
.hamburger:hover{background:var(--tint)}
.hamburger svg{width:24px;height:24px}

.mobile-menu{
  position:fixed;top:64px;left:0;right:0;z-index:99;
  background:#fff;border-bottom:1px solid var(--border);box-shadow:var(--shadow-2);
  padding:.5rem 0;
  visibility:hidden;opacity:0;transform:translateY(-8px);
  transition:opacity .18s,transform .18s,visibility .18s;
}
.mobile-menu.open{visibility:visible;opacity:1;transform:translateY(0)}
.mobile-menu a{
  display:block;padding:.85rem 24px;color:var(--ink);font-weight:500;font-size:1rem;
}
.mobile-menu a:hover{background:var(--tint);text-decoration:none}
.mobile-menu .btn{margin:.6rem 24px .4rem;display:flex}

.hero{padding:72px 0 56px;background:linear-gradient(180deg,#fff 0,var(--tint-blue) 100%)}
.hero-in{max-width:var(--maxw);margin:0 auto;padding:0 24px;text-align:center}
.hero h1{font-size:clamp(2rem,5vw,3.1rem);font-weight:700;letter-spacing:-.5px;max-width:18ch;margin:0 auto .5rem}
.hero .lede{font-size:1.15rem;color:var(--ink-2);max-width:60ch;margin:0 auto 2rem}
.hero .cta-row{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}
.hero-stats{display:flex;gap:2.5rem;justify-content:center;flex-wrap:wrap;margin-top:3rem}
.hero-stats .s b{display:block;font-size:1.7rem;font-weight:700;color:var(--blue)}
.hero-stats .s span{font-size:.9rem;color:var(--ink-2)}

section{padding:56px 0}
.sec-in{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.sec-head{text-align:center;max-width:62ch;margin:0 auto 2.5rem}
.sec-head h2{font-size:clamp(1.6rem,3.5vw,2.2rem);font-weight:700}
.sec-head p{color:var(--ink-2);font-size:1.05rem;margin:0}
.tint{background:var(--tint)}

.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}
.card{
  background:var(--surface);border:1px solid var(--border);border-radius:12px;
  padding:20px;display:flex;flex-direction:column;
  transition:box-shadow .18s,border-color .18s;
}
.card:hover{box-shadow:var(--shadow);border-color:#c6c9ce}
.card-top{display:flex;gap:14px;align-items:center;margin-bottom:14px}
.card-top img{width:60px;height:60px;border-radius:14px;border:1px solid var(--border);flex:none}
.card-top h3{font-size:1.1rem;font-weight:500;margin:0 0 2px}
.card-top .genre{color:var(--ink-2);font-size:.85rem;margin:0}
.rating{display:flex;align-items:center;gap:.3rem;color:var(--ink-2);font-size:.9rem;margin:0 0 14px}
.rating .stars{display:inline-flex;color:var(--star)}
.rating .stars svg{width:16px;height:16px}
.rating b{color:var(--ink);font-weight:500}
.card .meta-row{font-size:.85rem;color:var(--ink-2);margin:0 0 16px;display:flex;flex-wrap:wrap;gap:.4rem .9rem}
.card .meta-row span b{color:var(--ink);font-weight:500}
.card .card-cta{margin-top:auto}
.card .card-cta a{display:inline-flex;align-items:center;gap:.35em;font-weight:500;font-size:.92rem}
.card .card-cta svg{width:16px;height:16px}

.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px}
.cat{
  background:#fff;border:1px solid var(--border);border-radius:12px;padding:24px;
  transition:box-shadow .18s;
}
.cat:hover{box-shadow:var(--shadow)}
.cat .ci{
  width:48px;height:48px;border-radius:50%;background:var(--tint-blue);color:var(--blue);
  display:flex;align-items:center;justify-content:center;margin-bottom:14px;
}
.cat .ci svg{width:26px;height:26px}
.cat h4{font-size:1.05rem;font-weight:500;margin:0 0 4px}
.cat p{color:var(--ink-2);font-size:.92rem;margin:0}

.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:20px;text-align:center}
.stat b{display:block;font-size:2.1rem;font-weight:700;color:var(--blue)}
.stat span{color:var(--ink-2);font-size:.92rem}

.reviews{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}
.review{background:#fff;border:1px solid var(--border);border-radius:12px;padding:22px;transition:box-shadow .18s}
.review:hover{box-shadow:var(--shadow)}
.review .who{display:flex;align-items:center;gap:.7rem;margin-bottom:.8rem}
.review .av{width:40px;height:40px;border-radius:50%;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:500;flex:none}
.review .who .name{font-weight:500;font-size:.98rem}
.review .who .when{font-size:.8rem;color:var(--ink-2)}
.review .stars{color:var(--star);display:inline-flex;margin-bottom:.6rem}
.review .stars svg{width:18px;height:18px}
.review p{margin:0;color:#3c4043;font-size:.95rem}

.faq{max-width:760px;margin:0 auto}
.faq details{border-bottom:1px solid var(--border);padding:0}
.faq summary{
  list-style:none;cursor:pointer;padding:18px 40px 18px 4px;position:relative;
  font-weight:500;font-size:1.05rem;color:var(--ink);
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"";position:absolute;right:8px;top:22px;width:10px;height:10px;
  border-right:2px solid var(--ink-2);border-bottom:2px solid var(--ink-2);
  transform:rotate(45deg);transition:transform .2s;
}
.faq details[open] summary::after{transform:rotate(-135deg)}
.faq .a{padding:0 4px 20px;color:var(--ink-2)}
.faq .a p{margin:0}

.subscribe{max-width:680px;margin:0 auto;background:#fff;border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);padding:32px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{display:flex;flex-direction:column}
.field.full{grid-column:1 / -1}
.field label{font-size:.85rem;font-weight:500;color:var(--ink-2);margin-bottom:.35rem}
.field input[type=text],.field input[type=tel],.field input[type=email]{
  font-family:inherit;font-size:1rem;color:var(--ink);
  padding:.7rem .85rem;border:1px solid var(--border);border-radius:8px;background:#fff;
  transition:border-color .15s,box-shadow .15s;width:100%;
}
.field input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 1px var(--blue)}
.consent{flex-direction:row;align-items:flex-start;gap:.6rem;font-size:.9rem;color:var(--ink-2);font-weight:400}
.consent input{margin-top:.2rem;width:18px;height:18px;accent-color:var(--blue);flex:none}
.subscribe .btn{margin-top:1.2rem}
#successMsg{display:none;margin-top:1rem;padding:.8rem 1rem;background:#e6f4ea;border:1px solid #b7dfc1;color:#137333;border-radius:8px;font-size:.92rem}
#successMsg.show{display:block}

.foot{background:var(--tint);border-top:1px solid var(--border);padding:48px 0 28px;margin-top:24px}
.foot-grid{max-width:var(--maxw);margin:0 auto;padding:0 24px;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1.2fr;gap:32px}
.foot .brand{margin-bottom:1rem}
.foot p.muted{color:var(--ink-2);font-size:.9rem;max-width:34ch}
.foot .nap{font-style:normal;color:var(--ink-2);font-size:.9rem;line-height:1.8}
.foot .nap b{color:var(--ink)}
.foot h5{font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;color:var(--ink-2);font-weight:500;margin:0 0 .8rem}
.foot ul{list-style:none;margin:0;padding:0}
.foot ul li{margin-bottom:.5rem}
.foot ul a{color:var(--ink-2);font-size:.92rem}
.foot ul a:hover{color:var(--blue)}
.foot-bot{max-width:var(--maxw);margin:32px auto 0;padding:20px 24px 0;border-top:1px solid var(--border);display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem;color:var(--ink-2);font-size:.85rem}

.cookie{
  position:fixed;left:16px;right:16px;bottom:16px;z-index:150;max-width:560px;margin:0 auto;
  background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-2);
  padding:20px 22px;display:none;
}
.cookie.show{display:block}
.cookie p{margin:0 0 1rem;font-size:.9rem;color:var(--ink-2)}
.cookie .row{display:flex;gap:.6rem;flex-wrap:wrap}

.legal{max-width:780px;margin:0 auto;padding:48px 24px 24px}
.legal .crumb{font-size:.9rem;color:var(--ink-2);margin-bottom:1rem}
.legal h1{font-size:clamp(1.9rem,4vw,2.5rem);font-weight:700}
.legal .upd{color:var(--ink-2);font-size:.9rem;margin-bottom:2rem}
.legal h2{font-size:1.3rem;font-weight:500;margin-top:2rem}
.legal h3{font-size:1.05rem;font-weight:500;margin-top:1.4rem}
.legal ul{padding-left:1.3rem;color:#3c4043}
.legal li{margin-bottom:.5rem}
.legal .nap{font-style:normal;background:var(--tint);border:1px solid var(--border);border-radius:8px;padding:1rem 1.2rem;line-height:1.8;color:#3c4043}
.legal .back{display:inline-block;margin-top:2rem;font-weight:500}

.err{max-width:680px;margin:0 auto;padding:80px 24px;text-align:center}
.err .code{font-size:clamp(4rem,16vw,8rem);font-weight:700;color:var(--blue);line-height:1;margin:0}
.err h1{font-size:1.6rem;font-weight:500;margin:.5rem 0 1rem}
.err p{color:var(--ink-2);font-size:1.05rem}
.err .links{margin-top:1.6rem;color:var(--ink-2)}

@media (max-width:860px){
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .nav{display:none}
  .hamburger{display:inline-flex}
  .form-grid{grid-template-columns:1fr}
  .hero-stats{gap:1.6rem}
}
@media (max-width:520px){
  .foot-grid{grid-template-columns:1fr}
  .wrap,.sec-in,.hero-in,.appbar-in,.foot-grid,.foot-bot{padding-left:20px;padding-right:20px}
}

@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto !important;transition:none !important}
}
