/* Percussion Dream Pro — v1.2 homepage polish layer.
   Loaded after theme.css and tools.css so it overrides where needed. */

/* ===== Global rhythm / breathing room ===== */
.pdp-section{padding:96px 0}
@media (max-width:760px){.pdp-section{padding:64px 0}}
.pdp-section + .pdp-section{position:relative}
.pdp-section:not(.pdp-hero):not(.pdp-safety-strip):not(.pdp-footer)::before{
	content:"";display:block;position:absolute;left:50%;top:0;transform:translateX(-50%);
	width:120px;height:1px;background:linear-gradient(90deg,transparent,rgba(214,166,74,.35),transparent);
}

/* ===== Section header — eyebrow + decorative bar + gradient text ===== */
.pdp-section-header{margin-bottom:42px;max-width:780px}
.pdp-section-title{
	position:relative;padding-left:20px;font-weight:600;
	background:linear-gradient(180deg,#fff 0%,#f0e6d4 55%,#c9b387 100%);
	-webkit-background-clip:text;background-clip:text;color:transparent
}
.pdp-section-title::before{
	content:"";position:absolute;left:0;top:.35em;bottom:.35em;width:4px;border-radius:4px;
	background:linear-gradient(180deg,var(--pdp-gold),var(--pdp-brass));
	box-shadow:0 0 14px rgba(214,166,74,.45);
}
.pdp-section-sub{font-size:1.1rem;max-width:680px}
/* Print + non-WebKit fallback so text isn't invisible if background-clip:text fails. */
@supports not ((-webkit-background-clip: text) or (background-clip: text)){
	.pdp-section-title{color:var(--pdp-text);background:none}
}
@media print{.pdp-section-title{color:#1b1b1b;background:none;-webkit-text-fill-color:#1b1b1b}}

/* ===== HERO ===== */
.pdp-hero{padding:120px 0 130px;position:relative;overflow:hidden;isolation:isolate;background:
	radial-gradient(1200px 600px at 80% -10%, rgba(214,166,74,.22), transparent 60%),
	radial-gradient(900px 460px at 18% 110%, rgba(74,155,245,.12), transparent 70%),
	radial-gradient(700px 380px at 50% 50%, rgba(200,68,58,.06), transparent 60%),
	linear-gradient(180deg, #0a0b0e 0%, #0c0d10 70%, #08090c 100%)
}
.pdp-stage-grain{
	position:absolute;inset:0;pointer-events:none;opacity:.06;mix-blend-mode:overlay;
	background-image:radial-gradient(rgba(255,255,255,.6) 1px,transparent 1px);
	background-size:3px 3px;
}
.pdp-hero-rim{
	position:absolute;left:0;right:0;bottom:0;height:1px;
	background:linear-gradient(90deg,transparent 8%,rgba(214,166,74,.5) 50%,transparent 92%);
	opacity:.6
}
.pdp-stage-light-c{
	position:absolute;width:520px;height:520px;border-radius:50%;filter:blur(120px);opacity:.25;
	background:radial-gradient(circle,var(--pdp-teal),transparent 65%);
	top:50%;left:50%;transform:translate(-50%,-50%)
}
.pdp-waveform-a{position:absolute;left:0;right:0;bottom:24%;width:100%;color:rgba(214,166,74,.35);opacity:.4;animation:pdp-wave-a 8s ease-in-out infinite}
.pdp-waveform-b{position:absolute;left:0;right:0;bottom:34%;width:100%;color:rgba(74,155,245,.3);opacity:.3;animation:pdp-wave-b 11s ease-in-out infinite}
@keyframes pdp-wave-a{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes pdp-wave-b{0%,100%{transform:translateY(0) scaleY(1)}50%{transform:translateY(6px) scaleY(1.08)}}
@media (prefers-reduced-motion:reduce){.pdp-waveform-a,.pdp-waveform-b{animation:none}}

.pdp-hero-inner{position:relative;display:grid;grid-template-columns:1.35fr .95fr;gap:60px;align-items:center;z-index:1}
.pdp-hero-eyebrow{display:inline-flex;align-items:center;gap:10px;padding:7px 16px;background:rgba(214,166,74,.12);border:1px solid rgba(214,166,74,.35);color:var(--pdp-gold);border-radius:999px;font-size:.78rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:22px;backdrop-filter:blur(8px)}
.pdp-hero-eyebrow-dot{width:7px;height:7px;border-radius:50%;background:var(--pdp-gold);box-shadow:0 0 0 4px rgba(214,166,74,.15);animation:pdp-pulse-dot 2.2s ease-in-out infinite}
@keyframes pdp-pulse-dot{0%,100%{box-shadow:0 0 0 4px rgba(214,166,74,.15)}50%{box-shadow:0 0 0 8px rgba(214,166,74,0)}}
.pdp-hero-title{font-family:'Fraunces','Inter',Georgia,serif;font-size:clamp(2.4rem,5.2vw,4.4rem);line-height:1.04;letter-spacing:-.02em;margin:0 0 22px;background:linear-gradient(180deg,#fff 0%,#f0e6d4 60%,#c9b387 100%);-webkit-background-clip:text;background-clip:text;color:transparent}
.pdp-hero-sub{font-size:1.18rem;line-height:1.6;color:var(--pdp-muted);max-width:600px;margin:0 0 28px}
.pdp-hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:22px}
.pdp-btn-glow{box-shadow:0 14px 40px -10px rgba(214,166,74,.55),0 0 0 1px rgba(255,206,99,.4) inset;transition:box-shadow .2s ease,transform .2s ease}
.pdp-btn-glow:hover{box-shadow:0 18px 50px -10px rgba(214,166,74,.75),0 0 0 1px rgba(255,206,99,.55) inset;transform:translateY(-2px)}
.pdp-hero-chips{margin-top:18px}
.pdp-hero-chips a{transition:transform .2s ease,background .2s ease,border-color .2s ease}
.pdp-hero-chips a:hover{transform:translateY(-2px)}

/* Hero stats row */
.pdp-hero-stats{display:flex;gap:34px;flex-wrap:wrap;margin:30px 0 0;padding:20px 0 0;border-top:1px solid rgba(255,255,255,.06)}
.pdp-hero-stat{display:flex;flex-direction:column;gap:4px}
.pdp-hero-stat dt{font-family:'Fraunces',serif;font-size:2rem;font-weight:600;color:var(--pdp-gold);margin:0;line-height:1}
.pdp-hero-stat dd{margin:0;color:var(--pdp-muted);font-size:.85rem;text-transform:uppercase;letter-spacing:.06em;font-weight:500}

/* Hero widget — premium card */
.pdp-hero-widget{
	position:relative;background:
		radial-gradient(140% 100% at 50% 0%, rgba(214,166,74,.10), transparent 60%),
		linear-gradient(180deg, rgba(28,30,36,.85), rgba(14,15,19,.95));
	border:1px solid rgba(214,166,74,.28);border-radius:24px;
	padding:54px 28px 28px;display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center;
	box-shadow:0 40px 100px -30px rgba(0,0,0,.75),0 0 0 1px rgba(214,166,74,.05) inset,0 0 60px -20px rgba(214,166,74,.25) inset;
	backdrop-filter:blur(20px);overflow:hidden
}
.pdp-hero-widget::before{
	content:"";position:absolute;top:-1px;left:50%;transform:translateX(-50%);
	width:60%;height:1px;background:linear-gradient(90deg,transparent,rgba(214,166,74,.7),transparent)
}
.pdp-hero-widget .pdp-pb-badge{top:18px;background:linear-gradient(180deg,var(--pdp-gold),var(--pdp-brass));box-shadow:0 8px 24px -6px rgba(214,166,74,.6)}
.pdp-hero-widget-art{position:relative;display:flex;justify-content:center;margin-top:6px}
.pdp-hero-art-svg{filter:drop-shadow(0 14px 28px rgba(0,0,0,.5));animation:pdp-cymbal-shimmer 6s ease-in-out infinite}
@keyframes pdp-cymbal-shimmer{0%,100%{filter:drop-shadow(0 14px 28px rgba(0,0,0,.5))}50%{filter:drop-shadow(0 14px 28px rgba(0,0,0,.5)) drop-shadow(0 0 12px rgba(214,166,74,.3))}}
@media (prefers-reduced-motion:reduce){.pdp-hero-art-svg{animation:none}}
.pdp-hero-art-glow{position:absolute;inset:0;background:radial-gradient(closest-side,rgba(214,166,74,.25),transparent 70%);filter:blur(28px);pointer-events:none;z-index:-1}
.pdp-stick{transform-origin:110px 110px;animation:pdp-stick-tap 1.6s cubic-bezier(.4,0,.6,1) infinite}
@keyframes pdp-stick-tap{0%,100%{transform:rotate(-22deg)}45%{transform:rotate(-6deg)}50%{transform:rotate(-4deg)}55%{transform:rotate(-6deg)}}
@media (prefers-reduced-motion:reduce){.pdp-stick{animation:none}}

.pdp-hero-widget-title{font-family:'Fraunces',serif;font-size:1.35rem;margin:0}
.pdp-hero-widget-sub{margin:0;color:var(--pdp-muted);font-size:.92rem}

.pdp-hero-meter{width:100%;background:rgba(0,0,0,.35);border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:14px 16px;display:flex;flex-direction:column;gap:10px}
.pdp-hero-meter-row{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center}
.pdp-meter-key{font-family:'JetBrains Mono',monospace;font-size:.72rem;color:var(--pdp-muted);text-transform:uppercase;letter-spacing:.06em}
.pdp-meter-val{font-family:'JetBrains Mono',monospace;font-size:1.1rem;color:var(--pdp-gold);font-weight:700}
.pdp-meter-bars{display:flex;gap:3px;height:18px;align-items:flex-end}
.pdp-meter-bars i{display:block;width:5px;background:linear-gradient(180deg,var(--pdp-gold),var(--pdp-brass));border-radius:2px;animation:pdp-meter 1.4s ease-in-out infinite;transform-origin:bottom}
.pdp-meter-bars i:nth-child(1){animation-delay:.0s;height:30%}
.pdp-meter-bars i:nth-child(2){animation-delay:.1s;height:60%}
.pdp-meter-bars i:nth-child(3){animation-delay:.2s;height:90%}
.pdp-meter-bars i:nth-child(4){animation-delay:.3s;height:50%}
.pdp-meter-bars i:nth-child(5){animation-delay:.4s;height:80%}
.pdp-meter-bars i:nth-child(6){animation-delay:.5s;height:30%}
.pdp-meter-bars i:nth-child(7){animation-delay:.55s;height:70%}
.pdp-meter-bars i:nth-child(8){animation-delay:.6s;height:40%}
.pdp-meter-bars i:nth-child(9){animation-delay:.65s;height:85%}
.pdp-meter-bars i:nth-child(10){animation-delay:.7s;height:50%}
.pdp-meter-bars i:nth-child(11){animation-delay:.75s;height:65%}
.pdp-meter-bars i:nth-child(12){animation-delay:.8s;height:35%}
@keyframes pdp-meter{0%,100%{transform:scaleY(.6);opacity:.55}50%{transform:scaleY(1);opacity:1}}
@media (prefers-reduced-motion:reduce){.pdp-meter-bars i{animation:none}}

.pdp-hero-scroll{position:absolute;left:50%;bottom:20px;transform:translateX(-50%);z-index:2}
.pdp-hero-scroll-link{display:inline-flex;align-items:center;gap:6px;color:var(--pdp-muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;font-weight:600;background:rgba(0,0,0,.3);border:1px solid rgba(214,166,74,.2);border-radius:999px;padding:6px 14px;backdrop-filter:blur(6px)}
.pdp-hero-scroll-link:hover{color:var(--pdp-gold);border-color:rgba(214,166,74,.45)}

@media (max-width:900px){
	.pdp-hero{padding:80px 0 110px}
	.pdp-hero-inner{grid-template-columns:1fr;gap:36px}
	.pdp-hero-widget{order:2;padding:50px 22px 22px}
	.pdp-hero-stats{gap:22px}
	.pdp-hero-stat dt{font-size:1.6rem}
}

/* ===== Safety strip — stronger contrast band ===== */
.pdp-safety-strip{padding:22px 0;background:linear-gradient(90deg,rgba(200,68,58,.16),rgba(214,166,74,.08) 60%,rgba(214,166,74,.02));border-top:1px solid rgba(200,68,58,.22);border-bottom:1px solid rgba(200,68,58,.22)}
.pdp-safety-text{font-weight:500}
.pdp-safety-icon{width:36px;height:36px;border-radius:50%;background:rgba(200,68,58,.18);display:inline-flex;align-items:center;justify-content:center}

/* ===== Quick start — premium card grid ===== */
.pdp-quickstart-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px}
.pdp-quick-card{
	position:relative;background:linear-gradient(180deg,rgba(28,30,36,.7),rgba(14,15,19,.95));
	border:1px solid rgba(255,255,255,.06);border-radius:18px;padding:26px 18px;overflow:hidden;isolation:isolate;
	transition:transform .25s cubic-bezier(.2,.8,.2,1),border-color .25s ease,box-shadow .25s ease;
}
.pdp-quick-card::before{
	content:"";position:absolute;inset:0;border-radius:18px;padding:1px;
	background:linear-gradient(135deg,rgba(214,166,74,.6),transparent 50%,rgba(74,155,245,.35));
	-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
	-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .25s ease;pointer-events:none
}
.pdp-quick-card:hover{transform:translateY(-5px);box-shadow:0 24px 60px -22px rgba(0,0,0,.7)}
.pdp-quick-card:hover::before{opacity:1}
.pdp-quick-card.pdp-active{border-color:rgba(214,166,74,.6);box-shadow:0 0 0 1px rgba(214,166,74,.4),0 14px 40px -16px rgba(214,166,74,.35)}
.pdp-quick-icon{width:54px;height:54px;border-radius:16px;background:linear-gradient(135deg,rgba(214,166,74,.2),rgba(91,58,34,.35));box-shadow:0 6px 18px -6px rgba(214,166,74,.4);position:relative}
.pdp-quick-icon::after{content:"";position:absolute;inset:0;border-radius:16px;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.18),transparent 60%)}
.pdp-quick-label{font-size:1rem;font-weight:600}

/* ===== Quiz — radio-as-card option ===== */
.pdp-quiz-wrap{background:linear-gradient(180deg,rgba(28,30,36,.7),rgba(14,15,19,.95));border:1px solid rgba(255,255,255,.06);border-radius:22px;padding:36px;box-shadow:0 30px 80px -40px rgba(0,0,0,.65)}
.pdp-quiz-progress{height:8px;background:rgba(255,255,255,.05);border-radius:999px}
.pdp-quiz-progress-bar{box-shadow:0 0 12px rgba(214,166,74,.35)}
.pdp-quiz-options{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}
.pdp-quiz-option{position:relative;padding:16px 18px;border-radius:14px;cursor:pointer;transition:border-color .2s ease,background .2s ease,transform .15s ease;background:rgba(255,255,255,.03)}
.pdp-quiz-option:hover{transform:translateY(-1px);background:rgba(214,166,74,.07);border-color:rgba(214,166,74,.4)}
.pdp-quiz-option input{accent-color:var(--pdp-gold);width:18px;height:18px}
.pdp-quiz-option:has(input:checked){background:linear-gradient(135deg,rgba(214,166,74,.15),rgba(91,58,34,.12));border-color:rgba(214,166,74,.55);box-shadow:0 0 0 1px rgba(214,166,74,.35)}
.pdp-quiz-result{padding:30px;border-radius:20px}
.pdp-quiz-result h3{font-size:1.5rem;font-family:'Fraunces',serif}
.pdp-quiz-amz{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}

/* ===== Calculator / form grids — softer cards ===== */
.pdp-calc-form,.pdp-stick-form,.pdp-rhythm-form,.pdp-log-form,.pdp-maint-form,.pdp-planner-form,.pdp-hcheck-form{background:linear-gradient(180deg,rgba(28,30,36,.7),rgba(14,15,19,.95));border:1px solid rgba(255,255,255,.06);border-radius:20px;padding:28px;box-shadow:0 30px 80px -40px rgba(0,0,0,.55)}
.pdp-calc-result,.pdp-stick-result,.pdp-rhythm-output{padding:28px;border-radius:18px}

/* ===== Featured gear — cards with rim + badge variety ===== */
.pdp-featured-grid{gap:22px}
.pdp-product-box{padding:26px 22px;border-radius:20px;position:relative;background:linear-gradient(180deg,rgba(28,30,36,.7),rgba(14,15,19,.95))}
.pdp-product-box::after{
	content:"";position:absolute;inset:0;border-radius:20px;padding:1px;
	background:linear-gradient(160deg,rgba(214,166,74,.3),transparent 45%,rgba(58,166,160,.18));
	-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
	-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;opacity:.65
}
.pdp-product-box:hover{transform:translateY(-5px);box-shadow:0 30px 70px -28px rgba(0,0,0,.7)}
.pdp-pb-badge{padding:6px 14px;font-size:.7rem;background:linear-gradient(180deg,var(--pdp-gold),var(--pdp-brass));color:#181100 !important;box-shadow:0 8px 22px -6px rgba(214,166,74,.55)}
.pdp-pb-art{padding:8px 0;filter:drop-shadow(0 10px 18px rgba(214,166,74,.2))}
.pdp-pb-name{font-family:'Fraunces',serif;font-size:1.2rem}
.pdp-pb-best{font-size:.9rem}
.pdp-pb-chips{margin-top:2px}
.pdp-pb-actions .pdp-btn-amazon{justify-content:center;width:100%}

/* ===== Comparison table — cleaner ===== */
.pdp-compare-table{border-radius:18px;overflow:hidden;border:1px solid rgba(255,255,255,.06);box-shadow:0 24px 60px -28px rgba(0,0,0,.55)}
.pdp-compare-table thead th{background:linear-gradient(180deg,rgba(214,166,74,.12),rgba(214,166,74,.04));font-size:.72rem}
.pdp-compare-table tbody tr:hover{background:rgba(214,166,74,.04)}

/* ===== Rudiment tracker — grouped families + compact rows ===== */
.pdp-rudiment-progress-bar{height:10px;background:rgba(255,255,255,.06)}
.pdp-rudiment-progress-bar span{background:linear-gradient(90deg,var(--pdp-gold),var(--pdp-teal));box-shadow:0 0 18px rgba(214,166,74,.35)}

.pdp-rudiment-controls{flex-wrap:wrap;align-items:center}
.pdp-rudiment-viewmode{display:flex;gap:6px;margin-left:auto}
.pdp-rudiment-viewmode .pdp-chip{cursor:pointer}

.pdp-rudiment-families{display:flex;flex-direction:column;gap:14px}

.pdp-rudiment-family{
	background:linear-gradient(180deg,rgba(28,30,36,.7),rgba(14,15,19,.95));
	border:1px solid rgba(255,255,255,.06);border-radius:18px;overflow:hidden;
	box-shadow:0 18px 50px -34px rgba(0,0,0,.6)
}
.pdp-rudiment-family[open]{border-color:rgba(214,166,74,.25)}
.pdp-rudiment-family.pdp-rudiment-family-done{border-color:rgba(58,166,160,.4)}
.pdp-rudiment-family.pdp-rudiment-family-empty{display:none}

.pdp-rudiment-family-head{
	display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;
	padding:18px 22px;cursor:pointer;list-style:none;
	transition:background .2s ease
}
.pdp-rudiment-family-head::-webkit-details-marker{display:none}
.pdp-rudiment-family-head:hover{background:rgba(214,166,74,.04)}
.pdp-rudiment-family-toggle{
	width:28px;height:28px;border-radius:8px;
	background:rgba(214,166,74,.1);color:var(--pdp-gold);
	display:inline-flex;align-items:center;justify-content:center;
	transition:transform .2s ease
}
.pdp-rudiment-family[open] .pdp-rudiment-family-toggle{transform:rotate(90deg)}
.pdp-rudiment-family-label{display:flex;flex-direction:column;gap:2px;min-width:0}
.pdp-rudiment-family-label strong{font-family:'Fraunces',serif;font-size:1.05rem;color:var(--pdp-text);font-weight:600}
.pdp-rudiment-family-label small{color:var(--pdp-muted);font-size:.82rem}
.pdp-rudiment-family-meta{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.pdp-rudiment-family-count{color:var(--pdp-muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.pdp-rudiment-family-done{
	display:inline-flex;align-items:center;background:rgba(214,166,74,.1);
	border:1px solid rgba(214,166,74,.25);color:var(--pdp-gold);
	font-size:.74rem;padding:4px 10px;border-radius:999px;font-weight:700;letter-spacing:.04em;
	font-family:'JetBrains Mono',monospace
}
.pdp-rudiment-family.pdp-rudiment-family-done .pdp-rudiment-family-done{
	background:rgba(58,166,160,.12);border-color:rgba(58,166,160,.35);color:var(--pdp-teal)
}

/* Rows */
.pdp-rudiment-rows{list-style:none;margin:0;padding:0;border-top:1px solid rgba(255,255,255,.05)}
.pdp-rudiment-row{display:block;border-bottom:1px solid rgba(255,255,255,.04)}
.pdp-rudiment-row:last-child{border-bottom:0}
.pdp-rudiment-row.pdp-hidden{display:none}

.pdp-rudiment-row-toggle{
	display:grid;grid-template-columns:auto 1fr auto auto;gap:14px;align-items:center;
	width:100%;background:transparent;border:0;color:var(--pdp-text);
	padding:12px 22px;cursor:pointer;text-align:left;font-family:inherit;
	transition:background .15s ease
}
.pdp-rudiment-row-toggle:hover{background:rgba(214,166,74,.04)}
.pdp-rudiment-row-toggle:focus-visible{outline:2px solid var(--pdp-gold);outline-offset:-2px}

.pdp-rudiment-row-chevron{
	width:22px;height:22px;border-radius:6px;
	background:rgba(255,255,255,.04);color:var(--pdp-muted);
	display:inline-flex;align-items:center;justify-content:center;
	transition:transform .2s ease,color .2s ease,background .2s ease
}
.pdp-rudiment-row.pdp-rudiment-row-open .pdp-rudiment-row-chevron{transform:rotate(90deg);color:var(--pdp-gold);background:rgba(214,166,74,.12)}

.pdp-rudiment-row-name{font-weight:600;font-size:.96rem;color:var(--pdp-text)}

.pdp-rudiment-row-status{
	font-size:.7rem;padding:4px 10px;border-radius:999px;
	background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);color:var(--pdp-muted);
	text-transform:uppercase;letter-spacing:.06em;font-weight:700;white-space:nowrap
}
.pdp-rudiment-row-status[data-status="learning"]{background:rgba(74,155,245,.12);color:var(--pdp-blue);border-color:rgba(74,155,245,.3)}
.pdp-rudiment-row-status[data-status="clean"]{background:rgba(58,166,160,.12);color:var(--pdp-teal);border-color:rgba(58,166,160,.3)}
.pdp-rudiment-row-status[data-status="performance"]{background:rgba(214,166,74,.18);color:var(--pdp-gold);border-color:rgba(214,166,74,.4)}

.pdp-rudiment-row-tempo{
	display:inline-flex;align-items:baseline;gap:4px;
	font-family:'JetBrains Mono',monospace;color:var(--pdp-text);
	background:rgba(0,0,0,.25);border:1px solid rgba(255,255,255,.06);
	padding:5px 10px;border-radius:8px;min-width:74px;justify-content:center
}
.pdp-rudiment-row-tempo-val{font-size:.95rem;font-weight:700;color:var(--pdp-gold)}
.pdp-rudiment-row-tempo small{font-size:.66rem;color:var(--pdp-muted);text-transform:uppercase;letter-spacing:.05em}

/* Inline editor (revealed) */
.pdp-rudiment-row-edit{
	display:grid;grid-template-columns:1fr 1fr;gap:12px;
	padding:0 22px 18px 58px;
	animation:pdp-row-edit-in .18s ease both
}
@keyframes pdp-row-edit-in{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
.pdp-rudiment-field{display:flex;flex-direction:column;gap:6px;font-size:.82rem;color:var(--pdp-muted);font-weight:600}
.pdp-rudiment-field-wide{grid-column:1/-1}
.pdp-rudiment-field select,
.pdp-rudiment-field input,
.pdp-rudiment-field textarea{
	background:rgba(0,0,0,.25);color:var(--pdp-text);
	border:1px solid rgba(255,255,255,.08);border-radius:10px;
	padding:8px 12px;font-family:inherit;font-size:.92rem
}
.pdp-rudiment-field select:focus,
.pdp-rudiment-field input:focus,
.pdp-rudiment-field textarea:focus{outline:none;border-color:var(--pdp-gold);box-shadow:0 0 0 3px rgba(214,166,74,.15)}

/* "Cards" mode — opens every row inline for a denser overview */
.pdp-rudiment[data-view="cards"] .pdp-rudiment-rows{
	display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;
	padding:16px 22px;border-top:1px solid rgba(255,255,255,.05)
}
.pdp-rudiment[data-view="cards"] .pdp-rudiment-row{border:1px solid rgba(255,255,255,.06);border-radius:14px;background:rgba(0,0,0,.18)}
.pdp-rudiment[data-view="cards"] .pdp-rudiment-row-toggle{grid-template-columns:auto 1fr;padding:12px 14px}
.pdp-rudiment[data-view="cards"] .pdp-rudiment-row-status,
.pdp-rudiment[data-view="cards"] .pdp-rudiment-row-tempo{grid-column:2;justify-self:start;margin-top:4px}
.pdp-rudiment[data-view="cards"] .pdp-rudiment-row-edit{display:grid !important;padding:0 14px 14px;grid-template-columns:1fr 1fr}
.pdp-rudiment[data-view="cards"] .pdp-rudiment-row-chevron{display:none}

/* Mobile rebalance */
@media (max-width:640px){
	.pdp-rudiment-controls{gap:8px}
	.pdp-rudiment-viewmode{margin-left:0;width:100%;justify-content:flex-end}
	.pdp-rudiment-family-head{grid-template-columns:auto 1fr;row-gap:8px}
	.pdp-rudiment-family-meta{grid-column:1/-1;justify-content:flex-start;padding-left:42px}
	.pdp-rudiment-row-toggle{grid-template-columns:auto 1fr;row-gap:6px;padding:14px 18px}
	.pdp-rudiment-row-status,.pdp-rudiment-row-tempo{grid-column:2;justify-self:start}
	.pdp-rudiment-row-edit{padding:0 18px 16px 50px;grid-template-columns:1fr}
}

/* Print state: open everything for the printout */
@media print{
	.pdp-rudiment-row-edit{display:grid !important}
	.pdp-rudiment-family{break-inside:avoid}
}

/* ===== Setup visualizer — stage feels like a riser ===== */
.pdp-vis-stage{
	min-height:480px;background:
		radial-gradient(900px 360px at 50% 30%, rgba(214,166,74,.10), transparent 60%),
		linear-gradient(180deg, rgba(28,30,36,.7), rgba(14,15,19,.95));
	box-shadow:0 30px 80px -40px rgba(0,0,0,.6)
}
.pdp-vis-stage-floor{border:1px dashed rgba(214,166,74,.25);box-shadow:inset 0 0 40px rgba(214,166,74,.05)}
.pdp-vis-item{box-shadow:0 8px 22px -6px rgba(0,0,0,.5),0 0 0 1px rgba(255,255,255,.04) inset;font-weight:600}

/* ===== Setup generator — list rows with brass tag ===== */
.pdp-setupgen-list li{position:relative;padding-left:48px}
.pdp-setupgen-list li::before{
	content:"";position:absolute;left:14px;top:50%;transform:translateY(-50%);
	width:18px;height:18px;border-radius:5px;background:linear-gradient(180deg,var(--pdp-gold),var(--pdp-brass));opacity:.85
}

/* ===== Hearing checklist — premium row ===== */
.pdp-hcheck-item label{padding:16px 18px;border-radius:14px}
.pdp-hcheck-item label:hover{border-color:rgba(214,166,74,.35);background:rgba(214,166,74,.04)}

/* ===== Database — card grid polish ===== */
.pdp-db-grid{gap:16px}
.pdp-db-card{background:linear-gradient(180deg,rgba(28,30,36,.7),rgba(14,15,19,.95));border-radius:18px;padding:18px}
.pdp-db-card:hover{border-color:rgba(214,166,74,.4);transform:translateY(-3px);box-shadow:0 24px 60px -28px rgba(0,0,0,.6)}

/* ===== Beginner hub — feature card ===== */
.pdp-hub-grid{gap:16px}
.pdp-hub-card{position:relative;border-radius:18px;padding:22px;background:linear-gradient(180deg,rgba(28,30,36,.7),rgba(14,15,19,.95));overflow:hidden}
.pdp-hub-card::after{content:"";position:absolute;inset:auto -40px -40px auto;width:140px;height:140px;border-radius:50%;background:radial-gradient(closest-side,rgba(214,166,74,.18),transparent 70%);transition:transform .3s ease}
.pdp-hub-card:hover::after{transform:scale(1.2)}
.pdp-hub-title{font-family:'Fraunces',serif;font-size:1.1rem}

/* ===== Related products — bigger touch targets ===== */
.pdp-related-grid{gap:14px}
.pdp-related-card{padding:18px 14px;border-radius:18px;transition:transform .2s ease,border-color .2s ease}
.pdp-related-card:hover{transform:translateY(-3px);border-color:rgba(214,166,74,.4)}
.pdp-related-art{background:linear-gradient(135deg,rgba(214,166,74,.12),rgba(91,58,34,.18));border-radius:14px;padding:8px}

/* ===== FAQ — cleaner accordion ===== */
.pdp-faq-item{padding:18px 22px;border-radius:14px;transition:border-color .2s ease}
.pdp-faq-item[open]{border-color:rgba(214,166,74,.3);background:linear-gradient(180deg,rgba(214,166,74,.05),transparent)}
.pdp-faq-item summary{font-family:'Fraunces',serif;font-size:1.05rem}

/* ===== Newsletter — premium feature band ===== */
.pdp-newsletter{padding:64px 0}
.pdp-newsletter-inner{
	padding:48px;border-radius:28px;
	background:
		radial-gradient(600px 200px at 100% 0%, rgba(214,166,74,.18), transparent 60%),
		radial-gradient(600px 200px at 0% 100%, rgba(74,155,245,.12), transparent 60%),
		linear-gradient(180deg, rgba(28,30,36,.85), rgba(14,15,19,.95));
	border:1px solid rgba(214,166,74,.22);
	box-shadow:0 30px 80px -30px rgba(0,0,0,.6)
}
.pdp-newsletter-copy h2{font-size:clamp(1.6rem,2.6vw,2.2rem);font-family:'Fraunces',serif}
.pdp-newsletter-form input{padding:16px 22px}
.pdp-newsletter-form .pdp-btn{padding:14px 24px}

/* ===== Trust — bigger icons ===== */
.pdp-trust-card{padding:22px;border-radius:18px;background:linear-gradient(180deg,rgba(28,30,36,.7),rgba(14,15,19,.95))}
.pdp-trust-icon{width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,rgba(214,166,74,.18),rgba(91,58,34,.28));display:inline-flex;align-items:center;justify-content:center}

/* ===== Footer — premium close ===== */
.pdp-footer{margin-top:0;padding:80px 0 40px;background:
	radial-gradient(900px 300px at 50% 0%, rgba(214,166,74,.06), transparent 60%),
	linear-gradient(180deg,#08090c,#050608)}
.pdp-footer-title{font-size:.74rem;letter-spacing:.12em}
.pdp-footer-list a{transition:color .15s ease,padding-left .15s ease}
.pdp-footer-list a:hover{padding-left:6px}
.pdp-footer-bottom{padding-top:24px;font-size:.8rem}

/* ===== Mobile sticky CTA — premium pill ===== */
.pdp-mobile-cta{padding:16px;border-radius:18px;font-size:1rem;letter-spacing:.02em;box-shadow:0 22px 48px -10px rgba(0,0,0,.6),0 0 0 1px rgba(255,206,99,.5) inset}

/* ===== Comparison drawer — premium ===== */
.pdp-compare-drawer{border-radius:18px;padding:18px;background:linear-gradient(180deg,rgba(28,30,36,.95),rgba(14,15,19,.98));border:1px solid rgba(214,166,74,.4);box-shadow:0 30px 60px -16px rgba(0,0,0,.7)}

/* ===== Metronome pulse — CSS-level prefers-reduced-motion guard =====
   Defense-in-depth: even if metronome.js on disk is older and doesn't itself
   read prefers-reduced-motion, the pulse element will not scale or transition
   for users with reduced-motion preference. Color tint still applies so the
   beat indicator remains visible. */
@media (prefers-reduced-motion: reduce){
	.pdp-metronome-pulse{transition:background .12s ease !important}
	.pdp-metronome-pulse.active,
	.pdp-metronome-pulse.accent{transform:none !important}
	.pdp-metronome-dot{animation:none !important}
}

/* Collapsed compare badge — shown on page load when items already stored */
.pdp-compare-badge{
	position:fixed;right:18px;bottom:18px;z-index:55;
	display:inline-flex;align-items:center;gap:8px;
	background:linear-gradient(180deg,rgba(28,30,36,.95),rgba(14,15,19,.98));
	color:var(--pdp-text);border:1px solid rgba(214,166,74,.45);border-radius:999px;
	padding:10px 16px;cursor:pointer;font-family:inherit;font-weight:600;font-size:.88rem;
	box-shadow:0 18px 40px -14px rgba(0,0,0,.55),0 0 0 1px rgba(214,166,74,.08) inset;
	backdrop-filter:blur(10px);
	transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease
}
.pdp-compare-badge:hover{transform:translateY(-2px);border-color:rgba(214,166,74,.7);box-shadow:0 24px 48px -14px rgba(0,0,0,.6)}
.pdp-compare-badge-dot{
	width:8px;height:8px;border-radius:50%;background:var(--pdp-gold);
	box-shadow:0 0 0 4px rgba(214,166,74,.18);
	animation:pdp-pulse-dot 2.2s ease-in-out infinite
}
.pdp-compare-badge-count{
	display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;
	border-radius:999px;padding:0 7px;background:var(--pdp-gold);color:#181100;
	font-family:'JetBrains Mono',monospace;font-size:.78rem;font-weight:700
}
@media (prefers-reduced-motion:reduce){.pdp-compare-badge-dot{animation:none}}

/* ===== Lift-in animation on first view (kept subtle, respects reduced-motion) ===== */
@media (prefers-reduced-motion: no-preference){
	.pdp-section{animation:pdp-section-in .6s ease both;animation-timeline:view();animation-range:entry 0% cover 25%}
}
@keyframes pdp-section-in{from{opacity:.4;transform:translateY(14px)}to{opacity:1;transform:none}}

/* ===== Selection ===== */
::selection{background:rgba(214,166,74,.5);color:#0c0d10}
