/* ============================================================
   BORDER — Design System
   Editoriale, scuro, cinematografico. Tema accent per-opera.
   ============================================================ */
@import url('../fonts/fonts.css');

:root{
  /* base palette */
  --bg:        #0a090c;
  --bg-2:      #100e13;
  --surface:   rgba(255,255,255,.035);
  --surface-2: rgba(255,255,255,.06);
  --line:      rgba(255,255,255,.10);
  --line-soft: rgba(255,255,255,.06);
  --ink:       #f3efe7;
  --ink-soft:  #b8b2a8;
  --ink-mute:  #7d776e;

  /* brand accent (default) — sovrascritto per opera */
  --accent:      #e4b25b;
  --accent-soft: #f2cf86;
  --accent-deep: #7c5a1b;
  --g1: #2a2533;  --g2: #14121a;  --g3: #000000;

  --maxw: 1240px;
  --radius: 18px;
  --radius-lg: 26px;
  --ease: cubic-bezier(.2,.7,.2,1);
  --serif: 'Fraunces', 'Playfair Display', Georgia, 'Times New Roman', serif;
  --sans:  'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--bg); color:var(--ink);
  font-family:var(--sans); font-size:17px; line-height:1.7;
  font-weight:400; letter-spacing:.005em;
  overflow-x:hidden; min-height:100vh;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
::selection{background:var(--accent); color:#0a090c}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}

/* ----------------------------------------------- atmosfera globale */
.bg-field{position:fixed;inset:0;z-index:-2;pointer-events:none;overflow:hidden}
.bg-field::before{ /* grana */
  content:"";position:absolute;inset:0;opacity:.5;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.4'/%3E%3C/svg%3E");
}
.orb{position:fixed;z-index:-1;border-radius:50%;filter:blur(90px);opacity:.30;pointer-events:none;
  background:radial-gradient(circle at 30% 30%, var(--accent), transparent 70%);
  transition:background 1.2s var(--ease)}
.orb.a{width:50vw;height:50vw;top:-12vw;right:-10vw}
.orb.b{width:42vw;height:42vw;bottom:-14vw;left:-12vw;opacity:.18;
  background:radial-gradient(circle at 50% 50%, var(--g1), transparent 70%)}

/* scroll progress */
#progress{position:fixed;top:0;left:0;height:2px;width:0;z-index:120;
  background:linear-gradient(90deg,var(--accent),var(--accent-soft));box-shadow:0 0 12px var(--accent)}

/* ----------------------------------------------- layout */
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(20px,5vw,56px)}
.section{padding-block:clamp(64px,10vw,140px)}
.section-tight{padding-block:clamp(40px,6vw,72px)}

/* eyebrow / kicker */
.kicker{font-size:11px;font-weight:600;letter-spacing:.34em;text-transform:uppercase;
  color:var(--accent-soft);display:inline-flex;align-items:center;gap:.6em}
.kicker::before{content:"";width:26px;height:1px;background:var(--accent);opacity:.7}
.kicker.center::after{content:"";width:26px;height:1px;background:var(--accent);opacity:.7}
.kicker.center{justify-content:center}

h1,h2,h3,.serif{font-family:var(--serif);font-weight:600;line-height:1.04;letter-spacing:-.02em}
.display{font-weight:900;font-size:clamp(2.7rem,8vw,6.4rem);line-height:.96;letter-spacing:-.035em}
.h-sec{font-weight:900;font-size:clamp(2rem,4.6vw,3.6rem);letter-spacing:-.03em;line-height:1}
.lead{font-size:clamp(1.05rem,1.6vw,1.3rem);color:var(--ink-soft);max-width:62ch;line-height:1.75}
.muted{color:var(--ink-mute)}

/* ----------------------------------------------- nav */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;transition:.4s var(--ease)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:18px clamp(20px,5vw,56px);transition:.4s var(--ease)}
.nav.scrolled .nav-inner{padding-block:12px;
  background:rgba(10,9,12,.72);backdrop-filter:blur(18px) saturate(1.2);
  -webkit-backdrop-filter:blur(18px) saturate(1.2);border-bottom:1px solid var(--line-soft)}
.brand{font-family:var(--serif);font-weight:900;font-size:1.45rem;letter-spacing:.16em;
  display:inline-flex;align-items:center;gap:.5em}
.brand .dot{width:9px;height:9px;border-radius:50%;background:var(--accent);box-shadow:0 0 14px var(--accent)}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{font-size:13.5px;font-weight:500;color:var(--ink-soft);letter-spacing:.02em;
  position:relative;padding:6px 0;transition:.25s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;
  background:var(--accent);transition:width .3s var(--ease)}
.nav-links a:hover{color:var(--ink)} .nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-links a.active{color:var(--ink)}
.nav-cta{padding:9px 18px;border:1px solid var(--line);border-radius:100px;font-size:13px;
  font-weight:600;color:var(--ink);transition:.3s var(--ease)}
.nav-cta:hover{border-color:var(--accent);background:var(--accent);color:#0a090c}
.burger{display:none;flex-direction:column;gap:5px;padding:8px}
.burger span{width:24px;height:2px;background:var(--ink);transition:.3s;border-radius:2px}

/* ----------------------------------------------- buttons */
.btn{display:inline-flex;align-items:center;gap:.6em;padding:13px 24px;border-radius:100px;
  font-weight:600;font-size:14.5px;letter-spacing:.01em;transition:.3s var(--ease);
  border:1px solid transparent;white-space:nowrap}
.btn-primary{background:var(--accent);color:#0a090c}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 34px -10px var(--accent),0 0 0 1px var(--accent)}
.btn-ghost{border-color:var(--line);color:var(--ink);background:var(--surface)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent-soft);transform:translateY(-2px)}
.btn svg{width:18px;height:18px}

/* ----------------------------------------------- hero (home) */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:center;
  padding-top:120px;padding-bottom:60px}
.hero-tag{margin-bottom:30px}
.hero h1{margin-bottom:26px}
.hero h1 .out{-webkit-text-stroke:1.4px var(--ink);color:transparent;
  -webkit-text-fill-color:transparent}
.hero h1 em{font-style:italic;font-weight:400;color:var(--accent-soft)}
.hero-sub{display:flex;gap:40px;flex-wrap:wrap;align-items:flex-end;margin-top:18px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:36px}
.scroll-hint{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);
  font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-mute);
  display:flex;flex-direction:column;align-items:center;gap:10px}
.scroll-hint .line{width:1px;height:42px;background:linear-gradient(var(--accent),transparent);
  animation:scrolldot 2.2s var(--ease) infinite}
@keyframes scrolldot{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}
  51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* marquee */
.marquee{overflow:hidden;border-block:1px solid var(--line-soft);padding-block:18px;margin-top:60px;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.marquee-track{display:flex;gap:46px;width:max-content;animation:marq 48s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-track span{font-family:var(--serif);font-style:italic;font-size:1.5rem;color:var(--ink-soft);
  display:inline-flex;align-items:center;gap:46px;opacity:.7}
.marquee-track span::after{content:"✦";color:var(--accent);font-style:normal;font-size:.8rem}
@keyframes marq{to{transform:translateX(-50%)}}

/* ----------------------------------------------- stats / about strip */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;border-top:1px solid var(--line-soft);
  border-bottom:1px solid var(--line-soft);padding-block:40px}
.stat .n{font-family:var(--serif);font-weight:900;font-size:clamp(2rem,4vw,3rem);color:var(--ink);line-height:1}
.stat .l{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-mute);margin-top:8px}

/* ----------------------------------------------- gallery */
.gallery-head{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;
  flex-wrap:wrap;margin-bottom:46px}
.filters{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.filter{padding:8px 16px;border:1px solid var(--line);border-radius:100px;font-size:12.5px;
  font-weight:500;color:var(--ink-soft);transition:.25s var(--ease)}
.filter:hover{border-color:var(--ink-soft);color:var(--ink)}
.filter.active{background:var(--ink);color:#0a090c;border-color:var(--ink)}
.search{display:flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:100px;
  padding:8px 16px;background:var(--surface)}
.search input{background:none;border:none;outline:none;color:var(--ink);font-size:13.5px;width:150px}
.search svg{width:16px;height:16px;color:var(--ink-mute)}

.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:clamp(18px,2.2vw,30px)}
.card{position:relative;border-radius:var(--radius-lg);overflow:hidden;background:var(--surface);
  border:1px solid var(--line-soft);transition:.45s var(--ease);
  --c:var(--accent);will-change:transform}
.card:hover{transform:translateY(-7px);border-color:color-mix(in srgb,var(--c) 55%, transparent);
  box-shadow:0 30px 60px -28px rgba(0,0,0,.85), 0 0 0 1px color-mix(in srgb,var(--c) 30%,transparent)}
.card-cover{position:relative;aspect-ratio:1;overflow:hidden}
.card-cover img{width:100%;height:100%;object-fit:cover;transition:1.1s var(--ease);transform:scale(1.02)}
.card:hover .card-cover img{transform:scale(1.09)}
.card-cover::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 40%, rgba(8,7,10,.5) 75%, rgba(8,7,10,.95))}
.card-glow{position:absolute;inset:0;opacity:0;transition:.5s;mix-blend-mode:screen;
  background:radial-gradient(circle at 50% 30%, color-mix(in srgb,var(--c) 60%,transparent), transparent 70%)}
.card:hover .card-glow{opacity:.5}
.card-play{position:absolute;top:16px;right:16px;width:46px;height:46px;border-radius:50%;
  display:grid;place-items:center;background:rgba(10,9,12,.5);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.2);transform:scale(.6) translateY(-6px);opacity:0;transition:.4s var(--ease)}
.card:hover .card-play{transform:scale(1) translateY(0);opacity:1}
.card-play svg{width:18px;height:18px;fill:#fff;margin-left:2px}
.card-body{position:absolute;left:0;right:0;bottom:0;padding:20px 22px}
.card-kind{font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--c);font-weight:700;
  filter:brightness(1.4)}
.card-title{font-family:var(--serif);font-weight:600;font-size:1.42rem;line-height:1.08;margin-top:6px;
  letter-spacing:-.01em;text-shadow:0 2px 18px rgba(0,0,0,.8)}
.card-meta{display:flex;gap:10px;align-items:center;margin-top:10px;font-size:12px;color:var(--ink-soft)}
.tag-lang{padding:2px 9px;border:1px solid var(--line);border-radius:100px;font-size:10px;
  letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft)}
.card.hidden{display:none}

/* ----------------------------------------------- feature concept block */
.feature{position:relative;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);
  background:linear-gradient(135deg, rgba(255,255,255,.05), rgba(255,255,255,.01))}
.feature-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:0;align-items:stretch}
.feature-art{position:relative;min-height:420px;overflow:hidden}
.feature-art img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.feature-art::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(16,14,19,.9))}
.feature-text{padding:clamp(30px,4vw,60px);display:flex;flex-direction:column;justify-content:center}

/* ----------------------------------------------- OPERA PAGE */
.opera-atmo{position:fixed;inset:0;z-index:-2;overflow:hidden}
.opera-atmo .cover-blur{position:absolute;inset:-10%;background-size:cover;background-position:center;
  filter:blur(70px) saturate(1.3);transform:scale(1.15);opacity:.30;animation:drift 40s ease-in-out infinite alternate}
.opera-atmo .veil{position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(10,9,12,.72), var(--bg) 72%),
             radial-gradient(120% 60% at 50% 0%, color-mix(in srgb,var(--accent) 22%, transparent), transparent 60%)}
@keyframes drift{to{transform:scale(1.25) translate(2%, -2%)}}

.opera-hero{padding-top:140px;padding-bottom:40px}
.opera-hero-grid{display:grid;grid-template-columns:minmax(0,360px) 1fr;gap:clamp(30px,5vw,68px);align-items:center}
.cover-frame{position:relative;border-radius:22px;overflow:hidden;aspect-ratio:1;
  box-shadow:0 40px 90px -30px rgba(0,0,0,.9), 0 0 0 1px var(--line);
  transform:perspective(1200px) rotateY(0deg)}
.cover-frame img{width:100%;height:100%;object-fit:cover}
.cover-frame::after{content:"";position:absolute;inset:0;
  background:linear-gradient(160deg,color-mix(in srgb,var(--accent) 18%,transparent),transparent 50%);mix-blend-mode:overlay}
.opera-hero h1{font-size:clamp(2.6rem,6.4vw,5.4rem);font-weight:900;margin-block:14px 8px}
.opera-by{font-family:var(--serif);font-style:italic;font-size:1.5rem;color:var(--accent-soft)}
.opera-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px}

/* custom audio player */
.player{margin-top:30px;border:1px solid var(--line);border-radius:var(--radius);
  background:rgba(10,9,12,.55);backdrop-filter:blur(20px);padding:18px 20px}
.player-row{display:flex;align-items:center;gap:16px}
.play-btn{flex:none;width:54px;height:54px;border-radius:50%;background:var(--accent);color:#0a090c;
  display:grid;place-items:center;transition:.25s var(--ease)}
.play-btn:hover{transform:scale(1.06);box-shadow:0 0 30px -4px var(--accent)}
.play-btn svg{width:22px;height:22px;fill:currentColor}
.player-meta{flex:1;min-width:0}
.player-meta .pl-k{font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-mute);font-weight:700}
.player-meta .pl-t{font-weight:600;font-size:15px;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.eq{display:flex;align-items:flex-end;gap:3px;height:22px;width:30px;opacity:.25;transition:.3s}
.eq.on{opacity:1}
.eq i{width:3px;background:var(--accent);border-radius:3px;height:30%}
.eq.on i{animation:eq .9s ease-in-out infinite}
.eq i:nth-child(2){animation-delay:.2s}.eq i:nth-child(3){animation-delay:.4s}.eq i:nth-child(4){animation-delay:.1s}
@keyframes eq{0%,100%{height:20%}50%{height:100%}}
.progress-wrap{margin-top:14px;display:flex;align-items:center;gap:12px}
.bar{flex:1;height:5px;border-radius:5px;background:var(--surface-2);position:relative;cursor:pointer}
.bar .fill{position:absolute;inset:0;width:0;border-radius:5px;background:linear-gradient(90deg,var(--accent-deep),var(--accent))}
.bar .knob{position:absolute;top:50%;left:0;width:13px;height:13px;border-radius:50%;background:var(--accent);
  transform:translate(-50%,-50%);box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 30%,transparent);opacity:0;transition:opacity .2s}
.bar:hover .knob{opacity:1}
.time{font-size:12px;color:var(--ink-mute);font-variant-numeric:tabular-nums;min-width:42px;text-align:center}

/* ----------------------------------------------- content sections (opera) */
.opera-body{display:grid;grid-template-columns:1fr;gap:clamp(40px,6vw,72px);max-width:880px;margin-inline:auto}
.block{border-top:1px solid var(--line-soft);padding-top:40px}
.block-head{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-bottom:26px}
.block-head h2{font-size:clamp(1.5rem,3vw,2.1rem);font-weight:600}

/* audio recensione (analisi letta) */
.audio-review{margin:4px 0 30px;padding:20px 22px 8px;border:1px solid var(--line);border-radius:var(--radius);
  background:linear-gradient(135deg, color-mix(in srgb,var(--accent) 10%,transparent), transparent 60%)}
.audio-review .ar-cap{display:flex;align-items:center;gap:9px;font-size:12.5px;color:var(--accent-soft);
  font-weight:600;letter-spacing:.02em;margin-bottom:6px}
.audio-review .ar-cap svg{width:16px;height:16px}
.audio-review .player{margin-top:6px;border:none;background:transparent;padding:0 0 12px}

/* translation tool */
.trtool{margin-top:6px}
.tr-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  padding:10px;border:1px solid var(--line);border-radius:100px;background:var(--surface);width:fit-content}
.tr-bar .lbl{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-mute);
  padding-left:10px;display:inline-flex;align-items:center;gap:6px}
.tr-bar .lbl svg{width:14px;height:14px;color:var(--accent-soft)}
.langs{display:flex;gap:4px;flex-wrap:wrap}
.lang{padding:7px 13px;border-radius:100px;font-size:12px;font-weight:600;letter-spacing:.04em;
  color:var(--ink-soft);transition:.22s var(--ease);border:1px solid transparent}
.lang:hover{color:var(--ink);background:var(--surface-2)}
.lang.active{background:var(--accent);color:#0a090c}
.tr-tools{display:flex;gap:6px;margin-left:auto;padding-right:4px}
.tr-icon{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;color:var(--ink-soft);
  border:1px solid var(--line);transition:.22s}
.tr-icon:hover{color:var(--ink);border-color:var(--accent)}
.tr-icon svg{width:15px;height:15px}
.tr-status{font-size:12px;color:var(--ink-mute);margin-top:14px;display:flex;align-items:center;gap:9px;min-height:18px}
.tr-status .badge{padding:3px 9px;border-radius:100px;border:1px solid var(--line);
  font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-soft)}
.spin{width:14px;height:14px;border:2px solid var(--line);border-top-color:var(--accent);border-radius:50%;
  animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* review prose */
.prose{font-family:var(--serif);font-size:clamp(1.08rem,1.5vw,1.24rem);line-height:1.85;color:#e6e1d7;
  position:relative;transition:opacity .4s var(--ease)}
.prose.swapping{opacity:.25}
.prose p{margin-bottom:1.25em;hanging-punctuation:first}
.prose h3{font-family:var(--serif);font-size:1.45rem;font-weight:900;color:var(--ink);margin:1.8em 0 .7em;
  letter-spacing:-.02em;padding-left:16px;border-left:3px solid var(--accent)}
.prose h4{font-family:var(--sans);font-size:.8rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent-soft);margin:2em 0 .8em}
.prose em{font-style:italic;color:#fff}
.prose strong{font-weight:600;color:#fff;font-family:var(--sans);font-size:.94em}
.prose .sig{display:inline-block;margin-top:10px;font-style:italic;color:var(--accent-soft);
  font-size:1.1rem;letter-spacing:.1em}
.prose.side{display:grid;grid-template-columns:1fr 1fr;gap:34px}
.prose.side .col-h{font-family:var(--sans);font-size:10px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink-mute);margin-bottom:14px;display:block;border-bottom:1px solid var(--line-soft);padding-bottom:8px}

/* lyrics */
.lyrics{font-family:var(--serif);font-style:italic;text-align:center;font-size:clamp(1.25rem,2.4vw,1.7rem);
  line-height:1.55;color:#ece7dd;white-space:pre-line;transition:opacity .4s var(--ease)}
.lyrics.swapping{opacity:.2}
.lyrics .v{display:block;padding:.12em 0;transition:.3s}
.lyrics-card{background:radial-gradient(120% 100% at 50% 0%, color-mix(in srgb,var(--accent) 12%,transparent), transparent 60%);
  border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(34px,5vw,64px) clamp(20px,4vw,50px)}
.lyrics-side{display:grid;grid-template-columns:1fr 1fr;gap:30px;text-align:left}
.lyrics-side .lyrics{text-align:left}
.lyrics-side .col-h{font-family:var(--sans);font-style:normal;font-size:10px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--ink-mute);margin-bottom:16px;display:block}

/* links row */
.linkrow{display:flex;gap:14px;flex-wrap:wrap}
.platform{display:inline-flex;align-items:center;gap:10px;padding:12px 20px;border-radius:100px;
  border:1px solid var(--line);background:var(--surface);font-weight:600;font-size:14px;transition:.3s var(--ease)}
.platform svg{width:20px;height:20px}
.platform.sp:hover{background:#1DB954;color:#0a090c;border-color:#1DB954;transform:translateY(-2px)}
.platform.yt:hover{background:#FF0000;color:#fff;border-color:#FF0000;transform:translateY(-2px)}

/* prev / next */
.pager{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:20px}
.pager a{border:1px solid var(--line-soft);border-radius:var(--radius);padding:22px 24px;transition:.3s var(--ease);
  background:var(--surface)}
.pager a:hover{border-color:var(--accent);background:var(--surface-2);transform:translateY(-3px)}
.pager .dir{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-mute)}
.pager .t{font-family:var(--serif);font-size:1.3rem;margin-top:6px}
.pager .next{text-align:right}

/* ----------------------------------------------- bio */
.bio-hero{padding-top:150px}
.bio-portrait{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);aspect-ratio:4/5}
.bio-portrait img{width:100%;height:100%;object-fit:cover}
.timeline{position:relative;margin-top:30px;padding-left:30px}
.timeline::before{content:"";position:absolute;left:6px;top:6px;bottom:6px;width:1px;background:var(--line)}
.tl-item{position:relative;padding-bottom:34px}
.tl-item::before{content:"";position:absolute;left:-27px;top:6px;width:11px;height:11px;border-radius:50%;
  background:var(--accent);box-shadow:0 0 0 4px var(--bg),0 0 16px var(--accent)}
.tl-item h4{font-family:var(--serif);font-size:1.3rem;margin-bottom:4px}
.tl-item .yr{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent-soft)}
.album-tracks{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;margin-top:24px}
.track-chip{padding:16px 18px;border:1px solid var(--line-soft);border-radius:14px;background:var(--surface);
  display:flex;gap:12px;align-items:baseline;transition:.3s}
.track-chip:hover{border-color:var(--accent)}
.track-chip .num{font-family:var(--serif);color:var(--accent-soft);font-size:.95rem;font-weight:600}
.prose-bio{max-width:70ch}
.prose-bio p{margin-bottom:1.3em;color:var(--ink-soft);font-size:1.1rem;line-height:1.85}
.prose-bio p .drop{float:left;font-family:var(--serif);font-weight:900;font-size:4.2rem;line-height:.78;
  padding:6px 14px 0 0;color:var(--accent)}

/* ----------------------------------------------- community / guestbook */
.gb-form{border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(24px,3vw,38px);
  background:var(--surface)}
.field{margin-bottom:18px}
.field label{display:block;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute);
  margin-bottom:8px;font-weight:600}
.field input,.field textarea{width:100%;background:rgba(0,0,0,.25);border:1px solid var(--line);
  border-radius:12px;padding:13px 16px;color:var(--ink);font-family:inherit;font-size:15px;transition:.25s;resize:vertical}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent);
  box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 20%,transparent)}
.hp{position:absolute;left:-9999px;opacity:0}
.hearts{display:flex;gap:6px}
.hearts button{font-size:22px;color:var(--ink-mute);transition:.2s;line-height:1}
.hearts button.on,.hearts button:hover{color:var(--accent);transform:scale(1.15)}
.gb-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px;margin-top:36px}
.gb-card{border:1px solid var(--line-soft);border-radius:var(--radius);padding:24px;background:var(--surface);
  position:relative;transition:.3s}
.gb-card:hover{border-color:color-mix(in srgb,var(--accent) 40%,transparent)}
.gb-card .q{font-family:var(--serif);font-size:2.4rem;color:var(--accent);opacity:.4;line-height:.4;height:18px}
.gb-card .msg{font-family:var(--serif);font-size:1.12rem;line-height:1.6;color:#e6e1d7;margin:8px 0 16px}
.gb-card .who{display:flex;align-items:center;justify-content:space-between;gap:10px;
  border-top:1px solid var(--line-soft);padding-top:14px}
.gb-card .nm{font-weight:600;font-size:14px}
.gb-card .dt{font-size:11px;color:var(--ink-mute)}
.gb-card .rt{color:var(--accent);font-size:13px;letter-spacing:2px}
.gb-empty{text-align:center;color:var(--ink-mute);padding:50px;border:1px dashed var(--line);border-radius:var(--radius-lg)}

/* ----------------------------------------------- legal pages */
.legal{max-width:820px;margin-inline:auto}
.legal h1{font-size:clamp(2.2rem,5vw,3.4rem);font-weight:900;margin-bottom:10px}
.legal .updated{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:40px}
.legal h2{font-family:var(--serif);font-size:1.5rem;margin:2em 0 .6em;color:var(--ink);
  padding-left:14px;border-left:3px solid var(--accent)}
.legal h3{font-size:1.05rem;font-weight:700;margin:1.4em 0 .4em;color:var(--ink)}
.legal p,.legal li{color:var(--ink-soft);margin-bottom:.9em;line-height:1.8}
.legal ul{padding-left:22px;margin-bottom:1em}.legal li{margin-bottom:.5em}
.legal a{color:var(--accent-soft);text-decoration:underline;text-underline-offset:3px}
.legal .note{background:var(--surface);border:1px solid var(--line);border-left:3px solid var(--accent);
  border-radius:12px;padding:18px 22px;margin:1.4em 0}
.legal .ph{color:var(--accent-soft);background:color-mix(in srgb,var(--accent) 14%,transparent);
  padding:1px 7px;border-radius:5px;font-size:.92em}
.toc{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:40px}
.toc a{font-size:13px;padding:7px 14px;border:1px solid var(--line);border-radius:100px;
  color:var(--ink-soft);text-decoration:none;transition:.25s}
.toc a:hover{border-color:var(--accent);color:var(--ink)}

/* ----------------------------------------------- footer */
.footer{border-top:1px solid var(--line-soft);margin-top:40px;padding-block:64px 40px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;margin-bottom:50px}
.footer h5{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:18px}
.footer-links{display:flex;flex-direction:column;gap:11px}
.footer-links a{font-size:14px;color:var(--ink-soft);transition:.25s}
.footer-links a:hover{color:var(--accent-soft)}
.footer-brand .brand{font-size:1.8rem;margin-bottom:14px}
.footer-bottom{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;
  border-top:1px solid var(--line-soft);padding-top:26px;font-size:12.5px;color:var(--ink-mute)}

/* ----------------------------------------------- cookie banner */
.cookie{position:fixed;left:20px;right:20px;bottom:20px;z-index:130;max-width:560px;margin-inline:auto;
  background:rgba(16,14,19,.92);backdrop-filter:blur(20px);border:1px solid var(--line);
  border-radius:var(--radius-lg);padding:24px 26px;box-shadow:0 30px 70px -20px #000;
  transform:translateY(140%);transition:transform .6s var(--ease)}
.cookie.show{transform:translateY(0)}
.cookie h4{font-family:var(--serif);font-size:1.25rem;margin-bottom:8px}
.cookie p{font-size:13.5px;color:var(--ink-soft);margin-bottom:18px}
.cookie p a{color:var(--accent-soft);text-decoration:underline}
.cookie-actions{display:flex;gap:10px;flex-wrap:wrap}
.cookie-actions .btn{font-size:13px;padding:10px 18px}

/* toast */
.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%,120%);z-index:140;
  background:var(--accent);color:#0a090c;font-weight:600;font-size:14px;padding:13px 22px;border-radius:100px;
  box-shadow:0 14px 40px -10px var(--accent);transition:transform .45s var(--ease)}
.toast.show{transform:translate(-50%,0)}

/* ----------------------------------------------- reveal (fail-safe: nascosto SOLO con JS attivo) */
html.js .reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
html.js .reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}.reveal[data-d="4"]{transition-delay:.32s}

/* ----------------------------------------------- responsive */
@media (max-width:920px){
  .feature-grid{grid-template-columns:1fr}.feature-art{min-height:280px}
  .opera-hero-grid{grid-template-columns:1fr;text-align:center}
  .cover-frame{max-width:300px;margin-inline:auto}
  .opera-actions,.linkrow{justify-content:center}
  .prose.side,.lyrics-side{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:1fr 1fr;gap:24px}
}
@media (max-width:680px){
  body{font-size:16px}
  .nav-links{position:fixed;inset:0 0 0 auto;width:min(80vw,320px);flex-direction:column;justify-content:center;
    gap:26px;background:rgba(10,9,12,.97);backdrop-filter:blur(20px);padding:40px;
    transform:translateX(100%);transition:transform .4s var(--ease);border-left:1px solid var(--line)}
  .nav-links.open{transform:translateX(0)}
  .nav-links a{font-size:18px}.nav-cta{display:none}
  .burger{display:flex;z-index:101}
  .footer-grid{grid-template-columns:1fr}
  .hero-sub{flex-direction:column;gap:18px}
  .pager{grid-template-columns:1fr}
  .tr-bar{width:100%}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  html.js .reveal{opacity:1;transform:none}
}
