/* Rihulcz Luxury Official Website */
:root{
  --bg:#060606;
  --bg-soft:#0c0c0d;
  --panel:rgba(255,255,255,.065);
  --panel-strong:rgba(255,255,255,.105);
  --line:rgba(255,255,255,.13);
  --text:#f5f2eb;
  --muted:#a8a29a;
  --muted2:#d7d1c6;
  --gold:#d8b15e;
  --gold-light:#ffe7a8;
  --black:#030303;
  --radius:30px;
  --shadow:0 40px 120px rgba(0,0,0,.45);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  color:var(--text);
  background:
    radial-gradient(circle at 8% 2%,rgba(216,177,94,.22),transparent 30%),
    radial-gradient(circle at 92% 10%,rgba(255,255,255,.09),transparent 30%),
    linear-gradient(180deg,#050505 0%,#0d0d0f 48%,#050505 100%);
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  line-height:1.65;
  overflow-x:hidden;
}
body::selection{background:var(--gold);color:#111}
.grain{
  position:fixed;inset:0;pointer-events:none;z-index:5;opacity:.17;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 260 260' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.86' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.45'/%3E%3C/svg%3E");
}
.ambient{position:fixed;border-radius:999px;filter:blur(80px);opacity:.28;pointer-events:none}
.ambient-one{width:400px;height:400px;left:-160px;top:120px;background:var(--gold)}
.ambient-two{width:360px;height:360px;right:-140px;top:420px;background:#fff}
.site-header{
  width:min(1220px,92vw);
  margin:0 auto;
  padding:22px 0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  position:relative;
  z-index:10;
}
.brand{
  color:var(--text);
  text-decoration:none;
  font-weight:900;
  letter-spacing:-.04em;
  display:flex;
  align-items:center;
  gap:10px;
}
.brand span{
  display:inline-grid;
  place-items:center;
  width:34px;height:34px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold-light),var(--gold));
  color:#111;
}
nav{display:flex;gap:24px}
nav a{
  color:var(--muted);
  text-decoration:none;
  font-size:.92rem;
  font-weight:800;
  transition:.25s ease;
}
nav a:hover{color:var(--gold-light)}
main{width:min(1220px,92vw);margin:0 auto}
.hero{
  min-height:calc(100vh - 82px);
  display:grid;
  grid-template-columns:1.05fr .92fr;
  gap:64px;
  align-items:center;
  padding:58px 0 84px;
  position:relative;
}
.eyebrow{
  margin:0 0 16px;
  color:var(--gold-light);
  text-transform:uppercase;
  letter-spacing:.24em;
  font-size:.76rem;
  font-weight:900;
}
h1,h2,h3,p{margin-top:0}
h1{
  font-size:clamp(4.5rem,10.5vw,10.5rem);
  line-height:.82;
  margin:0 0 28px;
  letter-spacing:-.075em;
  font-weight:900;
}
h1 span{
  display:block;
  margin-top:18px;
  font-family:"Playfair Display",serif;
  font-size:clamp(2.4rem,5vw,5.3rem);
  letter-spacing:-.035em;
  color:transparent;
  -webkit-text-stroke:1px rgba(245,242,235,.55);
  font-weight:800;
}
.lead{
  max-width:720px;
  color:var(--muted2);
  font-size:clamp(1.12rem,2vw,1.42rem);
}
.hero-actions,.contact-actions{display:flex;flex-wrap:wrap;gap:13px;margin-top:30px}
.btn{
  min-height:50px;
  padding:0 22px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  text-decoration:none;
  font-weight:900;
  letter-spacing:-.02em;
  transition:.25s ease;
}
.btn.primary{
  color:#160f04;
  background:linear-gradient(135deg,var(--gold-light),var(--gold));
  box-shadow:0 18px 50px rgba(216,177,94,.25);
}
.btn.secondary{
  color:var(--text);
  border:1px solid var(--line);
  background:rgba(255,255,255,.045);
}
.btn:hover{transform:translateY(-2px)}
.hero-visual{position:relative}
.portrait-frame{
  border:1px solid var(--line);
  border-radius:44px;
  padding:16px;
  background:linear-gradient(180deg,rgba(255,255,255,.14),rgba(255,255,255,.04));
  box-shadow:var(--shadow);
  transform:rotate(1.2deg);
}
.portrait-frame img{
  display:block;
  width:100%;
  aspect-ratio:4/5.25;
  object-fit:cover;
  border-radius:32px;
  filter:saturate(.96) contrast(1.05);
}
.floating-card{
  position:absolute;
  z-index:2;
  width:172px;
  padding:16px;
  border:1px solid var(--line);
  border-radius:22px;
  background:rgba(8,8,8,.70);
  backdrop-filter:blur(18px);
  box-shadow:0 20px 60px rgba(0,0,0,.35);
}
.floating-card strong{
  display:block;
  font-size:1.8rem;
  letter-spacing:-.06em;
  color:var(--gold-light);
}
.floating-card span{color:var(--muted);font-size:.85rem;font-weight:800}
.card-a{left:-36px;bottom:16%}
.card-b{right:-18px;top:14%}
.identity-grid{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:1px;
  background:var(--line);
  border:1px solid var(--line);
  border-radius:28px;
  overflow:hidden;
  margin-bottom:42px;
}
.identity-grid div{background:rgba(255,255,255,.055);padding:22px 18px}
.identity-grid span{
  display:block;
  color:var(--muted);
  font-size:.78rem;
  font-weight:800;
  margin-bottom:6px;
}
.identity-grid strong{display:block;font-size:1rem;line-height:1.22}
.section{
  padding:84px 0;
  border-bottom:1px solid var(--line);
}
.split{
  display:grid;
  grid-template-columns:.95fr 1.1fr;
  gap:58px;
}
h2{
  font-size:clamp(2.25rem,5vw,5.1rem);
  line-height:1.02;
  margin:0;
  letter-spacing:-.045em;
  word-spacing:.03em;
  font-weight:900;
  text-wrap:balance;
}
.section-body p,.muted,.editorial-copy p,.ecosystem-card p,.timeline p{
  color:var(--muted2);
  font-size:1.05rem;
  line-height:1.78;
}
.centered{text-align:center;margin-inline:auto}
.max{max-width:720px;margin:18px auto 0}
.stats-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
  margin-top:34px;
}
.stats-grid article{
  padding:28px;
  border-radius:28px;
  border:1px solid var(--line);
  background:linear-gradient(180deg,rgba(255,255,255,.085),rgba(255,255,255,.035));
}
.stats-grid strong{
  display:block;
  font-size:clamp(2.2rem,5vw,4.4rem);
  line-height:.9;
  letter-spacing:-.08em;
  color:var(--gold-light);
}
.stats-grid span{
  display:block;
  margin-top:12px;
  color:var(--muted);
  font-weight:850;
}
.editorial-card{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:42px;
  align-items:center;
}
.editorial-image,.ecosystem-photo{
  border-radius:34px;
  overflow:hidden;
  border:1px solid var(--line);
  background:var(--panel);
  box-shadow:var(--shadow);
}
.editorial-image img,.ecosystem-photo img{
  display:block;
  width:100%;
  aspect-ratio:4/5;
  object-fit:cover;
}
.editorial-copy{
  padding:30px;
}
.ecosystem-layout{
  display:grid;
  grid-template-columns:.82fr 1.18fr;
  gap:34px;
  align-items:stretch;
  margin-top:32px;
}
.ecosystem-photo img{aspect-ratio:4/4.75}
.ecosystem-cards{display:grid;gap:14px}
.ecosystem-card{
  display:block;
  padding:28px;
  border-radius:28px;
  text-decoration:none;
  color:var(--text);
  border:1px solid var(--line);
  background:rgba(255,255,255,.052);
  transition:.25s ease;
}
.ecosystem-card:hover{transform:translateY(-3px);border-color:rgba(216,177,94,.55)}
.ecosystem-card span{
  color:var(--gold-light);
  text-transform:uppercase;
  letter-spacing:.18em;
  font-weight:900;
  font-size:.72rem;
}
.ecosystem-card strong{
  display:block;
  margin:8px 0;
  font-size:1.55rem;
  letter-spacing:-.055em;
}
.media-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
  margin-top:34px;
}
.media-card{
  min-height:232px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  padding:24px;
  border-radius:28px;
  text-decoration:none;
  color:var(--text);
  background:rgba(255,255,255,.055);
  border:1px solid var(--line);
  transition:.25s ease;
}
.media-card:hover{transform:translateY(-4px);border-color:rgba(216,177,94,.55)}
.media-card.featured{
  background:
    radial-gradient(circle at top right,rgba(216,177,94,.25),transparent 50%),
    rgba(255,255,255,.07);
}
.media-card span{color:var(--gold-light);font-weight:900}
.media-card strong{display:block;margin:12px 0;font-size:1.05rem;line-height:1.38}
.media-card em{font-style:normal;color:var(--muted);font-weight:850}
.media-card.disabled{opacity:.68}
.timeline{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
  margin-top:34px;
}
.timeline div{
  border:1px solid var(--line);
  background:rgba(255,255,255,.045);
  padding:24px;
  border-radius:26px;
}
.timeline span{
  display:inline-grid;
  place-items:center;
  width:38px;height:38px;
  border-radius:50%;
  background:rgba(216,177,94,.15);
  color:var(--gold-light);
  font-weight:900;
  margin-bottom:18px;
}
.timeline strong{display:block;font-size:1.05rem;letter-spacing:-.035em;margin-bottom:8px}
.visual-story{
  padding:84px 0;
  border-bottom:1px solid var(--line);
}
.visual-copy{
  display:flex;
  justify-content:space-between;
  align-items:end;
  gap:28px;
  margin-bottom:28px;
}
.visual-copy h2{max-width:760px}
.gallery{
  display:grid;
  grid-template-columns:1.1fr .9fr .9fr;
  gap:14px;
}
.gallery img{
  width:100%;
  height:520px;
  object-fit:cover;
  border-radius:32px;
  border:1px solid var(--line);
  background:var(--panel);
}
.gallery img:nth-child(2){height:420px;margin-top:84px}
.gallery img:nth-child(3){height:470px;margin-top:32px}
.contact-section{text-align:center}
.contact-actions{justify-content:center}
.note{margin-top:20px;color:var(--muted);font-size:.92rem}
.site-footer{
  width:min(1220px,92vw);
  margin:0 auto;
  padding:34px 0 50px;
  display:flex;
  justify-content:space-between;
  gap:20px;
  color:var(--muted);
}
.site-footer strong{display:block;color:var(--text)}
.site-footer a{color:var(--gold-light);text-decoration:none;font-weight:850}
[data-reveal]{
  opacity:0;
  transform:translateY(18px);
  transition:opacity .7s ease, transform .7s ease;
}
[data-reveal].is-visible{
  opacity:1;
  transform:none;
}

@media(max-width:980px){
  .hero,.split,.editorial-card,.ecosystem-layout{grid-template-columns:1fr}
  .identity-grid{grid-template-columns:repeat(3,1fr)}
  .stats-grid,.media-grid{grid-template-columns:repeat(2,1fr)}
  .timeline{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:1fr 1fr}
  .gallery img,.gallery img:nth-child(2),.gallery img:nth-child(3){height:430px;margin:0}
  .floating-card{position:static;width:auto;margin-top:10px}
  .hero-visual{display:grid;gap:10px}
}
@media(max-width:620px){
  nav{display:none}
  .site-header{padding:18px 0}
  .hero{padding:44px 0 56px;gap:32px}
  h1{
    font-size:clamp(3.55rem,18vw,6.4rem);
    line-height:.88;
    letter-spacing:-.055em;
  }
  h1 span{
    font-size:clamp(1.95rem,10vw,3.25rem);
    letter-spacing:-.02em;
  }
  h2{
    font-size:clamp(2.05rem,10vw,3.55rem);
    line-height:1.08;
    letter-spacing:-.028em;
    word-spacing:.04em;
  }
  .lead{
    font-size:1.05rem;
    line-height:1.72;
  }
  .portrait-frame{border-radius:30px;padding:10px;transform:none}
  .portrait-frame img{border-radius:22px}
  .identity-grid,.stats-grid,.media-grid,.timeline,.gallery{grid-template-columns:1fr}
  .identity-grid div{padding:18px}
  .section,.visual-story{padding:58px 0}
  .editorial-copy{padding:0}
  .gallery img,.gallery img:nth-child(2),.gallery img:nth-child(3){height:auto;aspect-ratio:4/5}
  .site-footer{display:block}
}
