:root{
  --ink:#0E2A3B; --paper:#F7F4EE; --card:#FFFFFF;
  --sea:#1E7FA8; --sea-deep:#155E7E; --sun:#F4A62A;
  --line:#E6DFD2; --muted:#5C6770; --ok:#1F8A5B;
  --shadow:0 1px 2px rgba(14,42,59,.06),0 8px 24px rgba(14,42,59,.06);
  --radius:14px;
  --display:'Space Grotesk',system-ui,sans-serif;
  --body:'Inter',system-ui,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--body);
     font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased}
.wrap{max-width:1040px;margin:0 auto;padding:0 20px}
.wrap.narrow{max-width:760px}
a{color:var(--sea-deep)}
.label{font-family:var(--display);text-transform:uppercase;letter-spacing:.14em;
       font-size:12px;font-weight:600;color:var(--sea)}

/* Hero */
.hero{padding:56px 0 30px}
.hero h1{font-family:var(--display);font-weight:700;font-size:clamp(30px,5vw,46px);
         line-height:1.05;margin:.5rem 0 0;letter-spacing:-.02em}
.hero p.sub{color:var(--muted);max-width:60ch;margin:.7rem 0 0;font-size:17px}
.scorecard{display:flex;flex-wrap:wrap;align-items:center;gap:28px;margin-top:28px;
           background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
           padding:24px 26px;box-shadow:var(--shadow)}
.score-big{font-family:var(--display);font-weight:700;font-size:58px;line-height:1;letter-spacing:-.02em}
.score-of{color:var(--muted);font-size:18px;font-weight:500}
.scoremeta{display:flex;flex-direction:column;gap:6px}
.scoremeta .count{color:var(--muted);font-size:14px}
.routeline{flex:1;min-width:120px;height:2px;background:
   repeating-linear-gradient(90deg,var(--line) 0 10px,transparent 10px 18px);position:relative}
.routeline::after{content:"";position:absolute;right:-2px;top:50%;width:9px;height:9px;
   border-radius:50%;background:var(--sun);transform:translateY(-50%)}
.cta{display:inline-flex;align-items:center;gap:8px;background:var(--sea);color:#fff;
     font-family:var(--display);font-weight:600;text-decoration:none;border:0;cursor:pointer;
     padding:13px 22px;border-radius:10px;font-size:15px;transition:background .15s,transform .15s}
.cta:hover{background:var(--sea-deep);transform:translateY(-1px)}
.cta.sun{background:var(--sun);color:var(--ink)}
.cta.sun:hover{background:#e0960f}
.cta.ghost{background:transparent;color:var(--sea-deep);border:1px solid var(--line)}
.cta.ghost:hover{border-color:var(--sea);background:#fff}

/* Stars */
.stars{display:inline-flex;gap:2px;vertical-align:middle}
.star{width:18px;height:18px;fill:#D9D2C4}
.star.on{fill:var(--sun)}

/* Controls */
.controls{display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:space-between;margin:34px 0 18px}
.search{flex:1;min-width:220px;position:relative}
.search input{width:100%;padding:12px 14px 12px 40px;border:1px solid var(--line);
              border-radius:10px;font-family:var(--body);font-size:15px;background:var(--card)}
.search input:focus{outline:2px solid var(--sea);outline-offset:1px;border-color:var(--sea)}
.search svg{position:absolute;left:13px;top:50%;transform:translateY(-50%);width:16px;height:16px;fill:var(--muted)}
.count-line{color:var(--muted);font-size:14px}

/* Review grid */
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
@media(max-width:680px){.grid{grid-template-columns:1fr}}
.review{background:var(--card);border:1px solid var(--line);border-left:3px solid var(--sea);
        border-radius:var(--radius);padding:20px 22px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:12px}
.review .top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.review .who{display:flex;align-items:center;gap:11px}
.avatar{width:38px;height:38px;border-radius:50%;background:var(--ink);color:#fff;
        font-family:var(--display);font-weight:600;display:flex;align-items:center;justify-content:center;font-size:15px;flex:none}
.review .name{font-weight:600;font-size:15px}
.review .name a{color:inherit;text-decoration:none}
.review .name a:hover{color:var(--sea-deep);text-decoration:underline}
.review .date{color:var(--muted);font-size:13px}
.review .body{font-size:15px;color:#2a3942}
.review-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;
             border-top:1px solid var(--line);padding-top:11px;margin-top:2px}
.verified{display:inline-flex;align-items:center;gap:5px;color:var(--ok);font-size:12px;font-weight:600;font-family:var(--display)}
.verified svg{width:14px;height:14px;fill:var(--ok)}
.permalink{font-family:var(--display);font-weight:500;font-size:13px;text-decoration:none;color:var(--sea-deep);white-space:nowrap}
.permalink:hover{text-decoration:underline}
.review.hidden{display:none}
.noresults{grid-column:1/-1;text-align:center;color:var(--muted);padding:40px}

/* Pagination */
.pager{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;align-items:center;margin:34px 0 10px}
.pager a,.pager span{min-width:40px;text-align:center;padding:9px 12px;border:1px solid var(--line);
      border-radius:9px;text-decoration:none;color:var(--ink);font-family:var(--display);font-weight:500;font-size:14px;background:var(--card)}
.pager a:hover{border-color:var(--sea);color:var(--sea-deep)}
.pager .cur{background:var(--ink);color:#fff;border-color:var(--ink)}
.pager .gap{border:0;background:none;color:var(--muted)}

/* Breadcrumb (página individual) */
.crumb{padding:26px 0 0;font-size:13px;color:var(--muted)}
.crumb a{color:var(--sea-deep);text-decoration:none}
.crumb a:hover{text-decoration:underline}

/* Single review */
.single{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
        box-shadow:var(--shadow);padding:34px 34px 30px;margin-top:14px}
.single .who{display:flex;align-items:center;gap:14px;margin-bottom:6px}
.single .avatar{width:52px;height:52px;font-size:20px}
.single .name{font-family:var(--display);font-weight:700;font-size:22px;letter-spacing:-.01em}
.single .date{color:var(--muted);font-size:14px}
.single .stars{margin:14px 0 6px}
.single blockquote{margin:18px 0 0;font-size:20px;line-height:1.55;color:var(--ink);
        border-left:3px solid var(--sun);padding-left:18px}
.single .meta-row{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-top:24px;
        border-top:1px solid var(--line);padding-top:18px}
.single .actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.related{margin-top:34px}
.related h2{font-family:var(--display);font-size:20px;margin:0 0 14px}

/* Form */
.formsec{margin:50px 0 30px;background:var(--card);border:1px solid var(--line);
         border-radius:var(--radius);box-shadow:var(--shadow);padding:30px 28px}
.formsec h2{font-family:var(--display);font-weight:700;font-size:26px;margin:.3rem 0 .4rem;letter-spacing:-.01em}
.formsec .note{color:var(--muted);font-size:14px;max-width:62ch}
.field{margin-top:16px}
.field label{display:block;font-weight:600;font-size:14px;margin-bottom:6px}
.field .req{color:var(--sea)}
.field input,.field textarea,.field select{width:100%;padding:12px 13px;border:1px solid var(--line);
     border-radius:10px;font-family:var(--body);font-size:15px;background:#fff}
.field input:focus,.field textarea:focus,.field select:focus{outline:2px solid var(--sea);outline-offset:1px;border-color:var(--sea)}
.field textarea{min-height:120px;resize:vertical}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:600px){.grid2{grid-template-columns:1fr}}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.filehint{font-size:13px;color:var(--muted);margin-top:6px}
.alert{padding:13px 16px;border-radius:10px;font-size:14px;margin-bottom:6px}
.alert.ok{background:#e8f6ee;color:#155e3c;border:1px solid #b9e4cb}
.alert.bad{background:#fdeeee;color:#8c2a2a;border:1px solid #f2c9c9}
.ratingpick{display:flex;gap:6px;direction:rtl;justify-content:flex-start}
.ratingpick input{position:absolute;opacity:0;pointer-events:none}
.ratingpick label{cursor:pointer;width:30px;height:30px;margin:0}
.ratingpick svg{width:30px;height:30px;fill:#D9D2C4;transition:fill .12s}
.ratingpick input:checked ~ label svg,
.ratingpick label:hover svg,
.ratingpick label:hover ~ label svg{fill:var(--sun)}

footer{border-top:1px solid var(--line);margin-top:40px;padding:26px 0 50px;color:var(--muted);font-size:13px}
@media (prefers-reduced-motion: reduce){*{transition:none!important;scroll-behavior:auto!important}}
:focus-visible{outline:2px solid var(--sea);outline-offset:2px}

/* Pastilla de origen de la reseña */
.src-pill{display:inline-flex;align-items:center;gap:5px;font-family:var(--display);
          font-weight:600;font-size:12px;padding:3px 9px;border-radius:999px;text-decoration:none;white-space:nowrap}
.src-pill.verified{color:var(--ok);background:#e8f6ee}
.src-pill.verified svg{width:13px;height:13px;fill:var(--ok)}
.src-pill.ext{color:var(--sea-deep);background:#e8f1f6}
.src-pill.ext:hover{background:#dceaf2}
code{background:#eee7d8;padding:1px 6px;border-radius:5px;font-size:13px}
