/* ===============================
   VARIABLES & BASE
   =============================== */
:root{
  /* layout tokens */
  --container: 72rem;
  --gutter: 1rem;
  --measure-ch: 68;
  --copy-lg: clamp(1.05rem, 0.5vw + 1rem, 1.25rem);

  /* rhythm & colors */
  --gap: 1.25rem;
  --gap-lg: 2rem;
  --line: 1.7;
  --text: #1f2937;
  --muted: #6b7280;
  --border:#e5e7eb;
  --accent:#0ea5e9;

  /* brand palette (base) */
  --brand-violet:#7c3aed; --brand-violet-hover:#5b21b6;
  --brand-teal:#14b8a6;   --brand-teal-hover:#0f766e;

  /* mandala palette */
  --mandala-red:       #EF4444; /* juicy red */
  --mandala-blue:      #2563EB; /* deep blue */
  --mandala-green:     #22C55E; /* clean green */
  --mandala-yellow:    #FFEA00; /* sunny yellow (brighter) */
  --mandala-lightblue: #38BDF8; /* sky blue */
  --mandala-teal:      #2DD4BF; /* teal */
  --mandala-pink:      #F472B6; /* pink */
  --mandala-orange:    #FB923C; /* warm orange */
  --mandala-violet:    #8B5CF6; /* violet */
  --mandala-white:     #FFFFFF; /* white (0) */


  /* hero height (desktop & mobile) */
  --hero-h-min: 260px;  --hero-h-vh: 52vh;  --hero-h-max: 560px;
  --hero-h-min-m: 160px;--hero-h-vh-m: 32vh;--hero-h-max-m: 320px;
}

html{ box-sizing:border-box }
*,*::before,*::after{ box-sizing:inherit }

body{
  margin:0; color:var(--text);
  font:400 16px/var(--line) system-ui,-apple-system,Segoe UI,Roboto,Inter,Arial,sans-serif;
  background:#fff;
}

a{ color:var(--accent); text-decoration:none }
a:hover{ text-decoration:underline }

.container{
  max-width:var(--container);
  margin:0 auto;
  padding:0 var(--gutter) 4rem;
}

/* ===============================
   ARTICLE GLOBAL
   =============================== */
article{ display:grid; gap:var(--gap-lg) }
/* комфортная мера по умолчанию */
.lead, .para__text{ max-width:min(100%, calc(var(--measure-ch) * 1ch)) }

/* ===============================
   HERO (image + title overlay)
   =============================== */
.hero{
  position:relative; margin:0 0 var(--gap-lg);
  height:clamp(var(--hero-h-min), var(--hero-h-vh), var(--hero-h-max));
  overflow:clip;
}
.hero>img{
  width:100%; height:100%; display:block; object-fit:cover;
  object-position: var(--hero-focus-x,50%) var(--hero-focus-y,30%);
}
.hero::after{
  content:""; position:absolute; inset:0; pointer-events:none; z-index:0;
  background:linear-gradient(180deg,rgba(0,0,0,.45),rgba(0,0,0,.15) 40%,rgba(0,0,0,.55));
}
.hero__content{
  position:absolute; inset:0; z-index:1;
  display:grid; place-items:end start; padding:1.5rem;
  padding-left:max(var(--gutter), calc((100vw - var(--container))/2 + var(--gutter)));
  padding-right:var(--gutter);
}
.hero__inner{ width:min(100%,70ch) }
.hero__title{
  margin:0 0 .35rem; color:#fff; font-weight:800; letter-spacing:-.01em; line-height:1.1;
  font-size:clamp(1.6rem, 2.6vw + 1rem, 3rem);
  text-shadow:0 1px 2px rgba(0,0,0,.35);
}
.hero__meta{ color:#fff; font-size:.975rem }

@media (max-width:900px){
  .hero__content{ padding-left:var(--gutter) }
}
@media (max-width:600px){
  .hero{
    height:clamp(var(--hero-h-min-m), var(--hero-h-vh-m), var(--hero-h-max-m));
  }
  .hero__content{ place-items:center start; padding:.75rem 1rem 1rem }
  .hero__title{ font-size:clamp(1.25rem, 4.4vw + .5rem, 1.75rem); text-wrap: balance; }
  .hero::after{
    background:linear-gradient(180deg,rgba(0,0,0,.52),rgba(0,0,0,.22) 40%,rgba(0,0,0,.62));
  }
}
/* option: conten to top on mobile */
@media (max-width:600px){
  .hero--mobile-top .hero__content{ place-items:start start }
}
/* Hero hight presets*/
.hero--compact{
  --hero-h-min: 220px;  --hero-h-vh: 40vh;  --hero-h-max: 420px;
  --hero-h-min-m: 140px;--hero-h-vh-m: 26vh;--hero-h-max-m: 240px;
}
.hero--slim{
  --hero-h-min: 180px;  --hero-h-vh: 34vh;  --hero-h-max: 360px;
  --hero-h-min-m: 130px;--hero-h-vh-m: 24vh;--hero-h-max-m: 220px;
}
/* increase header */
.hero--compact .hero__title{ font-size: clamp(1.5rem, 2.4vw + .9rem, 2.6rem) }
.hero--slim    .hero__title{ font-size: clamp(1.4rem, 2.2vw + .8rem, 2.4rem) }

/* ===============================
   LEAD (summary)
   =============================== */
.lead{
  max-width:none; width:100%;
  font-size: var(--copy-lg);
  line-height: 1.5;
  font-style:italic;
  margin:.75rem 0 var(--gap-lg);
}
.lead--violet{
  color:#4c1d95; background:rgba(124,58,237,.10);
  border-left:4px solid var(--brand-violet);
  padding:.75rem 1rem; border-radius:6px;
}
.lead--teal{
  color:#0f766e; background:rgba(20,184,166,.10);
  border-left:4px solid var(--brand-teal);
  padding:.75rem 1rem; border-radius:6px;
}
.lead--yellow{
  color: #92400e;                               /* dark text for contrast */
  background: rgba(255, 234, 0, .10);           /* from #FFEA00 */
  border-left: 4px solid var(--mandala-yellow, #FFEA00);
  padding: .75rem 1rem;
  border-radius: 6px;
}

/* Lead: red theme (non-brand) */
.lead--red{
  color: #991b1b;                               /* dark red text */
  background: rgba(239, 68, 68, .10);           /* from #EF4444 */
  border-left: 4px solid var(--mandala-red, #EF4444);
  padding: .75rem 1rem;
  border-radius: 6px;
}
@media (max-width:600px){
  .lead{ font-size:1.05rem }
}

/* ===============================
   PARAGRAPH (text + media)
   =============================== */
.para{ display:grid; gap:var(--gap); align-items:start }
.para__kicker{ color:var(--muted); margin:0; font-weight:600 }
.para__caption{ color:var(--muted); font-size:.9rem; margin-top:.25rem }

/* media image: aspect-ratio and focus settings*/
.para__media img{
  width:100%; height:auto; border-radius:8px;
  aspect-ratio: var(--ar, auto);   /* 16/9, 4/3, 1/1... */
  object-fit: cover; object-position: var(--focus, 50% 50%);
}
/* aspect utilities */
.media--16x9 img { aspect-ratio: 16/9 }
.media--4x3  img { aspect-ratio: 4/3  }
.media--1x1  img { aspect-ratio: 1/1  }

/* grid layout & width modes */
@media (min-width:900px){
  .para{ grid-template-columns:1fr 1fr; gap:var(--gap-lg) }
  .para--img-left  .para__media{ order:1 }  .para--img-left  .para__text{ order:2 }
  .para--img-right .para__text { order:1 }  .para--img-right .para__media{ order:2 }

  /* text wider */
  .para.para--img-right.para--text-wide { grid-template-columns: 1.2fr 0.8fr } /* text | media */
  .para.para--img-left.para--text-wide  { grid-template-columns: 0.8fr 1.2fr } /* media | text */

  /* image wider */
  .para.para--img-right.para--img-wide  { grid-template-columns: 0.8fr 1.2fr } /* text | media */
  .para.para--img-left.para--img-wide   { grid-template-columns: 1.2fr 0.8fr } /* media | text */
}
@media (max-width:899.98px){
  .para__media{ order:-1 } 
}

/* paragraph without image */
.para.para--full{ display:block; gap:0 }                /* off grid */
.para.para--full .para__text{ max-width:none; margin:0 }/* full-width */
.para.para--full.para--measure .para__text{
  max-width: calc(var(--measure-ch) * 1ch);
  margin: 0 auto;
}

/* paragraph typography */
.para__text p { font-size: var(--copy-lg); line-height: 1.55 }
.para__text li{ font-size: var(--copy-lg); line-height: 1.55 }
@media (max-width:600px){
  .para__text p, .para__text li { font-size: 1.05rem }
}

/* ===============================
   GALLERY
   =============================== */
.gallery{ display:grid; gap:var(--gap) }
.gallery--row{ grid-template-columns:repeat(auto-fit, minmax(180px,1fr)) }
.gallery figure{ margin:0 }
.gallery img{ width:100%; height:auto; display:block; border-radius:8px }
.gallery figcaption{ color:var(--muted); font-size:.9rem; margin-top:.25rem }

/* full-width gallery block */
.gallery-block{ display:grid; gap:var(--gap); width:100% }
.gallery--3{ grid-template-columns: repeat(3, 1fr) }
.gallery--4{ grid-template-columns: repeat(4, 1fr) }
.gallery--ratio-3x2  img{ aspect-ratio: 3 / 2;  width:100%; display:block; border-radius:8px; object-fit:cover }
.gallery--ratio-16x9 img{ aspect-ratio: 16 / 9; width:100%; display:block; border-radius:8px; object-fit:cover }
.gallery-block figure{ margin:0 }
.gallery-block figcaption{ color:var(--muted); font-size:.9rem; margin-top:.25rem }
@media (max-width:900px){
  .gallery--3, .gallery--4{ grid-template-columns: repeat(2, 1fr) }
}
@media (max-width:560px){
  .gallery--3, .gallery--4{ grid-template-columns: 1fr }
}

/* ===============================
   SEPARATOR IMAGE
   =============================== */
.separator{ margin-block: var(--gap-lg) }        /* delimiter */
.separator img{
  display:block; max-width:100%; height:auto;
  margin-inline:auto; border-radius:8px;         
}
.separator figcaption{
  color:var(--muted); font-size:.9rem; margin-top:.5rem; text-align:center
}
.separator--compact{ margin-block: var(--gap) }
.separator--bleed{
  margin-left: calc(-1 * var(--gutter));
  margin-right: calc(-1 * var(--gutter));
}

/* ===============================
   MISC
   =============================== */
blockquote{
  margin:0; padding:.75rem 1rem; border-left:4px solid var(--border);
  background:#fafafa; border-radius:6px;
  max-width:calc(var(--measure-ch) * 1ch);
}
/* Quote: full-width variant */
blockquote.q--full{ max-width: none; }

/* (option) bleed */
blockquote.q--bleed{
  max-width: none;
  margin-left:  calc(-1 * var(--gutter));
  margin-right: calc(-1 * var(--gutter));
}

hr{ border:none; height:1px; background:var(--border); margin:var(--gap-lg) 0 }

/* print: not add URL after links */
@media print{ a[href]::after{ content:none !important } }

/* Align hero text to the left container edge on wide screens */
figure.hero .hero__content {
  display: flex;                 
  align-items: flex-end;         
  justify-content: flex-start;   
}

/* Basic alignment on mobiles */
figure.hero .hero__inner {
  max-width: var(--container);
  margin-left: var(--gutter);
  margin-right: auto;
  padding-right: var(--gutter);
}

/* Stick to the left edge on wide screens */
@media (min-width: 1200px) {
  figure.hero .hero__inner {
    /* 72rem — current var(--container) */
    margin-left: calc((100% - 72rem) / 2 + var(--gutter));
    margin-right: auto;
  }
}

