/* ====== Els contes del senyor conill — landing ====== */
:root{
  --cream:#faf2db;
  --cream2:#f2e7ce;
  --ink:#3a2c1c;
  --brown:#96784a;
  --brown-d:#6e5631;
  --lightb:#cbb586;
  --gold:#ddaf54;
  --gold-d:#c4922f;
  --night:#2a2350;
  --night-d:#1b1740;
  --sea:#3f8fb0;
  --shadow:0 8px 24px rgba(58,44,28,.18);
  --serif:Georgia,'Times New Roman',serif;
  --body:'Segoe UI',system-ui,-apple-system,'Helvetica Neue',Arial,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--body);color:var(--ink);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;line-height:1.55;
}
img{max-width:100%;display:block}
h1,h2,h3{font-family:var(--serif);font-weight:700;line-height:1.15;margin:0}

/* idioma: mostra només l'idioma actiu */
body[data-lang="ca"] .i18.es{display:none}
body[data-lang="es"] .i18.ca{display:none}

/* ====== capçalera ====== */
.site-header{
  position:sticky;top:0;z-index:30;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:10px 16px;
  background:rgba(42,35,80,.96);color:#fdf7e6;
  box-shadow:0 2px 10px rgba(0,0,0,.25);
}
.brand{display:flex;align-items:center;gap:10px;color:inherit;text-decoration:none;min-width:0}
.brand-moon{width:30px;height:30px;flex:0 0 auto}
.brand-txt{font-family:var(--serif);font-size:.98rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lang-switch{display:flex;border:1px solid rgba(253,247,230,.5);border-radius:999px;overflow:hidden;flex:0 0 auto}
.lang-switch button{
  background:transparent;color:#fdf7e6;border:0;padding:6px 12px;font-size:.8rem;font-weight:700;cursor:pointer;letter-spacing:.03em;
}
.lang-switch button[aria-pressed="true"]{background:var(--gold);color:#3a2c1c}

/* ====== avís «el següent conte» ====== */
.next-banner{
  background:linear-gradient(90deg,#fff5db,#ffe9b0);
  color:#5a4420;border-bottom:1px solid var(--lightb);
  padding:12px 16px;text-align:center;font-size:.95rem;
  display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:center;
}
.next-banner b{font-family:var(--serif)}

/* ====== HERO ====== */
.hero{
  position:relative;min-height:78vh;display:flex;align-items:center;justify-content:center;
  text-align:center;color:#fdf7e6;overflow:hidden;
  background:linear-gradient(180deg,rgba(20,17,46,.45),rgba(20,17,46,.78)),
             #15122e url("../img/hero-bg.jpg") center 30%/cover no-repeat;
}
.hero-stars{position:absolute;inset:0;
  background-image:
    radial-gradient(1.5px 1.5px at 20% 30%,#fff6d6 50%,transparent),
    radial-gradient(1.5px 1.5px at 70% 20%,#fff6d6 50%,transparent),
    radial-gradient(2px 2px at 85% 60%,#fff6d6 50%,transparent),
    radial-gradient(1.5px 1.5px at 40% 70%,#fff6d6 50%,transparent),
    radial-gradient(1.5px 1.5px at 55% 40%,#fff6d6 50%,transparent),
    radial-gradient(2px 2px at 12% 75%,#fff6d6 50%,transparent);
  opacity:.8}
.hero-inner{position:relative;z-index:2;padding:30px 22px;max-width:760px}
.hero h1{font-size:clamp(1.9rem,7vw,3.4rem);text-shadow:0 2px 18px rgba(0,0,0,.45)}
.hero-sub{font-size:clamp(1rem,3.3vw,1.3rem);margin:14px 0 26px;opacity:.95;font-style:italic}
.scroll-hint{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);color:#fdf7e6;
  font-size:2rem;text-decoration:none;opacity:.8;animation:bob 1.8s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}

/* ====== botons ====== */
.btn{display:inline-block;border-radius:999px;padding:11px 22px;font-weight:700;text-decoration:none;cursor:pointer;border:0;font-size:1rem;transition:transform .12s ease,box-shadow .12s ease}
.btn:active{transform:translateY(1px)}
.btn-gold{background:var(--gold);color:#3a2c1c;box-shadow:0 4px 0 var(--gold-d)}
.btn-gold:hover{box-shadow:0 6px 0 var(--gold-d);transform:translateY(-1px)}
.btn-soon{background:#e7dcc2;color:#8a7656;box-shadow:0 4px 0 #cdbf9f;cursor:default}

/* ====== seccions ====== */
.section{max-width:1080px;margin:0 auto;padding:54px 18px}
.section h2{font-size:clamp(1.5rem,5vw,2.3rem);text-align:center;color:var(--brown-d)}
.section h2::after{content:"";display:block;width:64px;height:4px;border-radius:4px;background:var(--gold);margin:12px auto 0}
.section-lead{text-align:center;color:#7a6648;margin:10px auto 26px;max-width:560px}
.section-mon{background:
  radial-gradient(60% 40% at 50% 0%,rgba(221,175,84,.10),transparent),
  var(--cream)}

/* ====== mapa ====== */
.mapa-wrap{position:relative;border-radius:18px;overflow:hidden;background:var(--cream2);
  border:3px solid var(--lightb);box-shadow:var(--shadow);max-width:560px;margin:0 auto 30px}
.mapa{display:block;width:100%;height:auto}
.mapa-img{display:block;width:100%;height:auto}
.mapa-pins{position:absolute;inset:0}
.hot-pin{position:absolute;transform:translate(-50%,-50%);width:34px;height:34px;border-radius:50%;
  border:3px solid #fff6d6;background:radial-gradient(circle at 50% 38%,#ffe9a8,#ddaf54);
  box-shadow:0 2px 8px rgba(0,0,0,.35);cursor:pointer;padding:0;animation:pinpulse 2.4s ease-out infinite}
.hot-pin:hover,.hot-pin:focus{outline:none;background:radial-gradient(circle at 50% 38%,#fff,#e8c061);
  transform:translate(-50%,-50%) scale(1.14)}
@keyframes pinpulse{0%{box-shadow:0 0 0 0 rgba(255,246,214,.55)}100%{box-shadow:0 0 0 15px rgba(255,246,214,0)}}
.hot{cursor:pointer}
.hot .halo{fill:url(#hot-g)}
.hot .dot{fill:#fff6d6;stroke:var(--gold-d);stroke-width:2}
.hot .ring{fill:none;stroke:#fff6d6;stroke-width:2;transform-box:fill-box;transform-origin:center;animation:pulse 2.4s ease-out infinite}
.hot:hover .dot,.hot:focus .dot{fill:var(--gold)}
.hot:focus{outline:none}
@keyframes pulse{0%{transform:scale(.6);opacity:.9}100%{transform:scale(2.4);opacity:0}}
@media (prefers-reduced-motion:reduce){.hot .ring,.hot-pin{animation:none}.scroll-hint{animation:none}}

/* ====== graella de targetes (racons) ====== */
.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px}
.card{
  background:#fff;border:2px solid var(--lightb);border-radius:16px;overflow:hidden;
  text-align:left;cursor:pointer;padding:0;box-shadow:var(--shadow);
  transition:transform .14s ease;font-family:inherit;color:inherit;
}
.card:hover{transform:translateY(-3px)}
.card .card-img{aspect-ratio:4/3;background:#e9dfc6 center/cover no-repeat}
.card .card-body{padding:10px 12px}
.card .card-nom{font-family:var(--serif);font-weight:700;font-size:.98rem;color:var(--brown-d)}
.card.soon .card-img{display:flex;align-items:center;justify-content:center;background:#ece2cb;color:#b09a6e;font-size:2rem}
.card .soon-tag{display:inline-block;margin-top:4px;font-size:.72rem;color:#b09a6e;font-weight:700;text-transform:uppercase;letter-spacing:.05em}

/* ====== biblioteca ====== */
.section-bib{background:
  linear-gradient(180deg,rgba(95,175,208,.07),transparent 40%),var(--cream)}
.llibres-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:22px}
.llibre{background:#fff;border:2px solid var(--lightb);border-radius:16px;overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;position:relative}
.llibre .llibre-cob{aspect-ratio:148/210;background:#e9dfc6 center/cover no-repeat}
.llibre .llibre-body{padding:12px 14px 16px;display:flex;flex-direction:column;gap:6px;flex:1}
.llibre .llibre-num{font-size:.74rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-d)}
.llibre .llibre-tit{font-family:var(--serif);font-weight:700;font-size:1.04rem;color:var(--brown-d);line-height:1.2}
.llibre .llibre-lema{font-size:.86rem;color:#7a6648;font-style:italic;flex:1}
.llibre .btn{margin-top:8px;text-align:center;font-size:.92rem;padding:9px 16px}
.llibre-btns{display:flex;flex-direction:column;gap:8px;margin-top:10px}
.btn-fmt{margin-top:0;text-align:center;font-size:.9rem;padding:9px 12px}
.llibre.is-last{border-color:var(--gold)}
.llibre .ribbon{position:absolute;top:10px;left:-34px;transform:rotate(-45deg);background:var(--gold);color:#3a2c1c;font-size:.7rem;font-weight:700;padding:4px 40px;box-shadow:0 2px 6px rgba(0,0,0,.2)}
.serie-amazon{text-align:center;margin:26px 0 0}
.serie-link{color:var(--brown-d);font-weight:700;text-decoration:none;border-bottom:2px solid var(--gold);padding-bottom:2px}
.serie-link:hover{color:var(--gold-d)}

/* ====== autora ====== */
.section-autora{background:var(--cream)}
.autora-card{display:grid;grid-template-columns:1fr;gap:22px;max-width:880px;margin:0 auto;
  background:#fff;border:2px solid var(--lightb);border-radius:20px;padding:18px;box-shadow:var(--shadow)}
.autora-fig{margin:0;border-radius:14px;overflow:hidden;background:var(--night-d)}
.autora-fig svg,.autora-img{display:block;width:100%;height:auto}
.autora-txt p{margin:0 0 12px;font-size:1.02rem}
.autora-nom{font-family:var(--serif);font-weight:700;font-size:1.2rem;color:var(--brown-d)}

/* ====== peu ====== */
.site-footer{position:relative;overflow:hidden;background:var(--night);color:#fdf7e6;text-align:center;padding:30px 16px;display:flex;flex-direction:column;align-items:center;gap:8px}
.foot-moon{width:34px;height:34px}
.site-footer p{margin:0;font-family:var(--serif);font-style:italic;opacity:.9}
.foot-deco{position:absolute;bottom:0;width:auto;opacity:.96;pointer-events:none}
.foot-conill{left:16px;height:110px}
.foot-cargol{right:18px;height:46px}
@media (max-width:600px){.foot-deco{display:none}}

/* hilera d'amics (personatges retallats) */
.amics{display:flex;align-items:flex-end;justify-content:center;flex-wrap:wrap;
  gap:clamp(6px,3.2vw,34px);max-width:1000px;margin:0 auto;padding:22px 16px 4px}
.amics img{height:clamp(64px,12vw,128px);width:auto;
  filter:drop-shadow(0 9px 7px rgba(58,44,28,.22))}
/* proporcions reals: elefant/girafa més grans; lluerna/cargol més petits */
.amics .big{height:clamp(96px,18vw,182px)}
.amics .small{height:clamp(48px,9vw,92px)}
.amics .tiny{height:clamp(26px,5vw,52px)}
.amics-lead{text-align:center;color:#7a6648;font-style:italic;font-size:.95rem;margin:8px auto 0}
.amics button{background:none;border:0;padding:0;margin:0;cursor:pointer;display:inline-flex;align-items:flex-end;line-height:0}
.amics button img{transition:transform .15s ease}
.amics button:hover img,.amics button:focus img{transform:translateY(-7px) scale(1.06)}
.amics button:focus{outline:none}
.char-img-wrap{display:flex;justify-content:center;align-items:flex-end;min-height:190px;padding:22px 18px 0}
#char-img{max-height:240px;max-width:78%;width:auto;filter:drop-shadow(0 10px 12px rgba(58,44,28,.22))}

/* cursor conill (només escriptori amb ratolí) */
@media (hover:hover) and (pointer:fine){
  body{cursor:url("../img/cur-conill.png") 2 2, auto}
  a,button,.card,.llibre .btn,.hot,.hot-pin,.lang-switch button,.modal-close{
    cursor:url("../img/cur-conill.png") 2 2, pointer}
}

/* ====== modal ====== */
.modal{position:fixed;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;padding:16px}
.modal[hidden]{display:none}
.modal-backdrop{position:absolute;inset:0;background:rgba(27,23,64,.7);backdrop-filter:blur(2px)}
.modal-card{position:relative;z-index:2;background:var(--cream);border:3px solid var(--gold);border-radius:20px;
  max-width:520px;width:100%;max-height:90vh;overflow:auto;box-shadow:0 18px 50px rgba(0,0,0,.4);
  animation:pop .18s ease-out}
@keyframes pop{from{transform:scale(.94);opacity:0}to{transform:scale(1);opacity:1}}
.modal-img{aspect-ratio:4/3;background:#e9dfc6 center/cover no-repeat;border-radius:17px 17px 0 0}
.modal-img-el{display:block;width:100%;height:auto;border-radius:17px 17px 0 0}
.modal-card h3{padding:16px 20px 0;font-size:1.4rem;color:var(--brown-d)}
.modal-card p{padding:8px 20px 22px;margin:0;font-size:1.05rem}
.modal-close{position:absolute;top:8px;right:10px;z-index:3;width:38px;height:38px;border-radius:50%;border:0;
  background:rgba(255,255,255,.9);color:#3a2c1c;font-size:1.5rem;line-height:1;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.25)}

/* ====== escriptori ====== */
@media (min-width:760px){
  .mapa-wrap{max-width:620px}
  .autora-card{grid-template-columns:1.1fr 1fr;align-items:center;padding:26px}
  .section{padding:70px 22px}
}
