/* Case — Rosenberg & Hite (cinematic law firm) */
.case--rh { background: #0E0E10; color: #F2EAD3; font-family: 'Inter Tight', 'Manrope', sans-serif; }

.rh-eyebrow {
	font-family: 'Fraunces', serif; font-style: italic; font-size: .95rem;
	letter-spacing: .12em; text-transform: uppercase;
	color: #C9A24A; margin: 0 0 1em;
}
.rh-eyebrow--ink { color: #6A5A2A; }

.rh-h2 {
	font-family: 'Fraunces', serif; font-weight: 400;
	font-size: clamp(2rem, 4.6vw, 3.2rem);
	line-height: 1.05; letter-spacing: -.01em;
	margin: 0 0 .5em; color: #F2EAD3;
}
.rh-h2--ink { color: #1B1408; }

.rh-btn {
	display: inline-flex; align-items: center; gap: 8px;
	padding: 14px 26px; border-radius: 0;
	font-family: 'Inter Tight', sans-serif; font-weight: 600;
	font-size: .94rem; letter-spacing: .04em; text-decoration: none;
	transition: transform .25s var(--ac-ease-out), background .25s, color .25s;
}
.rh-btn--brass { background: #C9A24A; color: #0E0E10; }
.rh-btn--brass:hover { transform: translateY(-2px); background: #D9B25A; }
.rh-btn--ghost { background: transparent; color: #F2EAD3; border: 1px solid rgba(242,234,211,.2); }
.rh-btn--ghost:hover { border-color: #C9A24A; color: #C9A24A; transform: translateY(-2px); }

/* HERO storm */
.rh-hero {
	position: relative;
	padding: clamp(80px, 12vw, 160px) 0 clamp(60px, 9vw, 100px);
	overflow: hidden;
	background: linear-gradient(180deg, #14141A 0%, #0E0E10 100%);
}
.rh-storm { position: absolute; inset: 0; overflow: hidden; opacity: .5; pointer-events: none; }
.rh-rain {
	position: absolute; inset: 0;
	background-image:
		repeating-linear-gradient(95deg, transparent 0 8px, rgba(178,193,210,.3) 8px 9px, transparent 9px 14px);
	animation: rh-rain 1.6s linear infinite;
	mask-image: linear-gradient(180deg, transparent 0%, #000 25%, #000 100%);
	-webkit-mask-image: linear-gradient(180deg, transparent 0%, #000 25%, #000 100%);
}
.rh-rain--2 { animation-duration: 2.1s; opacity: .5; }
@keyframes rh-rain { from { transform: translate(0,0); } to { transform: translate(-40px, 200px); } }
@media (prefers-reduced-motion: reduce) { .rh-rain { animation: none; } }
.rh-skyline {
	position: absolute; bottom: 0; left: 0; right: 0; height: 30%;
	background:
		linear-gradient(180deg, transparent 0%, rgba(14,14,16,.9) 80%),
		repeating-linear-gradient(90deg, #1F1F26 0 60px, #15151A 60px 100px, #1A1A20 100px 160px);
	clip-path: polygon(0 60%, 8% 50%, 15% 55%, 22% 35%, 32% 45%, 40% 25%, 50% 40%, 60% 30%, 70% 50%, 82% 35%, 90% 55%, 100% 45%, 100% 100%, 0 100%);
}
.rh-figure {
	position: absolute; bottom: 14%; left: 35%; width: 80px; height: 120px;
}
.rh-figure__umbrella {
	position: absolute; top: 0; left: 50%; transform: translateX(-50%);
	width: 70px; height: 30px;
	background: #0A0A0C;
	border-radius: 50% 50% 0 0 / 100% 100% 0 0;
}
.rh-figure__body {
	position: absolute; bottom: 0; left: 50%; transform: translateX(-50%);
	width: 22px; height: 70px;
	background: #0A0A0C;
	border-radius: 11px 11px 4px 4px;
}
.rh-sign {
	position: absolute; top: 30%; right: 8%;
	font-family: 'Fraunces', serif; font-style: italic;
	font-size: clamp(.8rem, 1.4vw, 1.1rem); letter-spacing: .14em;
	color: #C9A24A;
	text-shadow: 0 0 12px rgba(201,162,74,.6);
	animation: rh-sign-flicker 4s ease-in-out infinite;
}
@keyframes rh-sign-flicker { 0%,100%{opacity:1;} 92%{opacity:1;} 94%{opacity:.3;} 96%{opacity:1;} }
@media (prefers-reduced-motion: reduce) { .rh-sign { animation: none; } }

.rh-hero__inner { position: relative; z-index: 2; max-width: 900px; }
.rh-title {
	font-family: 'Fraunces', serif; font-weight: 400;
	font-size: clamp(2.4rem, 6vw, 4.6rem);
	line-height: 1.02; letter-spacing: -.015em;
	margin: 0 0 32px;
}
.rh-title span { display: block; }
.rh-title__ital em { font-style: italic; color: #C9A24A; }
.rh-tagline { max-width: 56ch; color: #B5AC92; line-height: 1.6; margin: 0 0 32px; font-size: 1.05rem; }
.rh-tagline em { color: #C9A24A; font-style: italic; }
.rh-hero__cta { display: flex; flex-wrap: wrap; gap: 12px; }

/* SECTIONS */
.rh-section { padding: clamp(70px, 10vw, 130px) 0; border-top: 1px solid rgba(201,162,74,.1); }
.rh-section--cream { background: #F2EAD3; color: #1B1408; }
.rh-split { display: grid; grid-template-columns: 1fr 1.3fr; gap: 60px; align-items: start; }
@media (max-width: 880px) { .rh-split { grid-template-columns: 1fr; gap: 24px; } }
.rh-split p { margin: 0 0 1.2em; line-height: 1.7; color: #B5AC92; max-width: 56ch; }
.rh-section--cream .rh-split p { color: #4A3E2A; }
.rh-split p em { color: #C9A24A; font-style: italic; }
.rh-split code { font-family: 'JetBrains Mono', monospace; background: rgba(201,162,74,.1); padding: 2px 6px; border-radius: 3px; font-size: .9em; color: #C9A24A; }

/* ACTS */
.rh-acts { list-style: none; padding: 0; margin: 40px 0 0; display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
@media (max-width: 880px) { .rh-acts { grid-template-columns: 1fr; } }
.rh-act {
	display: flex; gap: 20px; align-items: flex-start;
	background: rgba(201,162,74,.04);
	border-left: 2px solid #C9A24A;
	padding: 22px 24px;
	transition: background .25s, transform .25s var(--ac-ease-out);
}
.rh-act:hover { background: rgba(201,162,74,.08); transform: translateX(4px); }
.rh-act__num {
	font-family: 'Fraunces', serif; font-style: italic;
	font-size: 1.8rem; color: #C9A24A;
	min-width: 50px;
}
.rh-act h3 {
	font-family: 'Fraunces', serif; font-weight: 500;
	font-size: 1.15rem; margin: 0 0 4px; color: #F2EAD3;
}
.rh-act p { font-size: .92rem; color: #8C8268; line-height: 1.5; margin: 0; }

/* DETAILS */
.rh-details { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 40px; }
@media (max-width: 880px) { .rh-details { grid-template-columns: 1fr; } }
.rh-detail {
	background: rgba(201,162,74,.04);
	border: 1px solid rgba(201,162,74,.15);
	padding: 28px;
	transition: border-color .25s, transform .25s var(--ac-ease-out);
}
.rh-detail:hover { border-color: #C9A24A; transform: translateY(-4px); }
.rh-detail h3 {
	font-family: 'Fraunces', serif; font-weight: 500; font-style: italic;
	font-size: 1.25rem; margin: 0 0 10px; color: #C9A24A;
}
.rh-detail p { color: #B5AC92; line-height: 1.55; margin: 0; font-size: .94rem; }

/* QUOTE */
.rh-quote-section {
	background:
		radial-gradient(50% 60% at 50% 50%, rgba(201,162,74,.06), transparent 70%),
		#0A0A0C;
	padding: clamp(80px, 12vw, 140px) 0;
	text-align: center;
	border-top: 1px solid rgba(201,162,74,.2);
	border-bottom: 1px solid rgba(201,162,74,.2);
}
.rh-quote { max-width: 780px; margin: 0 auto; }
.rh-quote p {
	font-family: 'Fraunces', serif; font-style: italic;
	font-size: clamp(1.4rem, 3vw, 2.2rem);
	line-height: 1.35; color: #F2EAD3;
	margin: 0 0 24px; position: relative;
}
.rh-quote p::before {
	content: '"'; position: absolute; top: -.4em; left: -.4em;
	font-size: 4em; color: #C9A24A; opacity: .25;
}
.rh-quote cite {
	font-family: 'Inter Tight', sans-serif; font-style: normal;
	font-size: .85rem; letter-spacing: .14em; text-transform: uppercase;
	color: #C9A24A;
}

/* STACK */
.rh-stack {
	display: grid; grid-template-columns: max-content 1fr;
	gap: 16px 36px; margin: 0;
	background: rgba(201,162,74,.04);
	border: 1px solid rgba(201,162,74,.15);
	padding: 30px;
}
@media (max-width: 600px) { .rh-stack { grid-template-columns: 1fr; gap: 4px 0; } }
.rh-stack dt {
	font-family: 'Fraunces', serif; font-style: italic;
	font-size: .95rem; color: #C9A24A; padding-top: 4px;
}
.rh-stack dd { margin: 0; font-size: .98rem; color: #F2EAD3; line-height: 1.5; }
@media (max-width: 600px) {
	.rh-stack dd { padding-bottom: 12px; border-bottom: 1px dashed rgba(201,162,74,.1); margin-bottom: 8px; }
}
