:root{
  --cream:#fbfaf4;
  --cream-2:#f4f0e5;
  --green:#124b32;
  --green-2:#3f9b4e;
  --soft-green:#e8f2df;
  --pink:#ff7d86;
  --yellow:#f5c84b;
  --blue:#80c8e9;
  --text:#21342b;
  --muted:#5f6f65;
  --white:#fff;
  --shadow:0 18px 45px rgba(23,67,43,.10);
  --radius:28px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  position:relative;
  font-family:"Nunito Sans",Arial,sans-serif;
  background:var(--cream);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
}

main{
  position:relative;
  z-index:1;
}

.site-decorations{
  position:absolute;
  inset:0;
  pointer-events:none;
  overflow:hidden;
  z-index:0;
}

.decor-element{
  position:absolute;
  display:block;
  width:76px;
  height:76px;
  border-radius:999px;
  opacity:0.9;
  filter:drop-shadow(0 14px 28px rgba(18,75,50,.10));
  will-change: transform;
}

.decor-element svg{
  width:100%;
  height:100%;
  display:block;
}

.float-a{animation:siteFloat 11s ease-in-out infinite alternate;}
.float-b{animation:siteFloat 13s ease-in-out infinite alternate;}
.float-c{animation:siteFloat 16s ease-in-out infinite alternate;}
.float-d{animation:siteFloat 12s ease-in-out infinite alternate;}
.float-e{animation:siteFloat 14s ease-in-out infinite alternate;}
.float-f{animation:siteFloat 10s ease-in-out infinite alternate;}
.float-g{animation:siteFloat 15s ease-in-out infinite alternate;}
.float-h{animation:siteFloat 13s ease-in-out infinite alternate;}
.float-i{animation:siteFloat 12s ease-in-out infinite alternate;}
.float-j{animation:sectionFloat 14s ease-in-out infinite alternate;}
.float-k{animation:sectionFloat 12s ease-in-out infinite alternate;}
.float-l{animation:sectionFloat 16s ease-in-out infinite alternate;}
.float-m{animation:sectionFloat 13s ease-in-out infinite alternate;}
.float-n{animation:sectionFloat 11s ease-in-out infinite alternate;}
.float-o{animation:sectionFloat 15s ease-in-out infinite alternate;}
.float-p{animation:sectionFloat 10s ease-in-out infinite alternate;}
.float-q{animation:sectionFloat 17s ease-in-out infinite alternate;}
.float-r{animation:sectionFloat 13s ease-in-out infinite alternate;}

@keyframes siteFloat {
  0% { transform: translateY(0) scale(1); }
  100% { transform: translateY(-12px) scale(1.02); }
}

@keyframes sectionFloat {
  0% { transform: translateY(0) scale(1); }
  100% { transform: translateY(-10px) scale(1.015); }
}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.container{width:min(1120px,calc(100% - 48px));margin:0 auto}
.section{padding:78px 0;position:relative;overflow:hidden}

.section-decorations{
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:0;
}

.section-decorations .decor-element{
  opacity:.7;
  filter:drop-shadow(0 12px 22px rgba(18,75,50,.08));
}

.section .container{
  position:relative;
  z-index:1;
}

.site-header{
  position:sticky;
  top:0;
  z-index:30;
  background:rgba(251,250,244,.88);
  backdrop-filter:blur(18px);
  box-shadow:0 8px 30px rgba(18,75,50,.08);
}
.nav-wrap{
  height:88px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}
.brand{display:flex;align-items:center;gap:13px;font-weight:800;color:var(--green)}
.brand-text{display:flex;flex-direction:column;line-height:1.15;font-size:18px}
.brand-text em{font-style:normal;font-size:18px}
.flower-logo{width:54px;height:54px;position:relative;display:inline-block}
.flower-logo span{position:absolute;width:20px;height:20px;border-radius:50% 50% 50% 8px;background:#f25e62;left:17px;top:17px;transform-origin:10px 10px}
.flower-logo span:nth-child(1){transform:translateY(-17px) rotate(45deg)}
.flower-logo span:nth-child(2){transform:translateX(17px) rotate(135deg)}
.flower-logo span:nth-child(3){transform:translateY(17px) rotate(225deg)}
.flower-logo span:nth-child(4){transform:translateX(-17px) rotate(315deg)}
.flower-logo span:nth-child(5){background:#2e8c4f;border-radius:50%;width:16px;height:16px;left:19px;top:19px}
.flower-logo.small{width:44px;height:44px;transform:scale(.82)}

.main-nav{display:flex;align-items:center;gap:30px;font-weight:700;font-size:15px}
.main-nav a{padding:32px 0 28px;border-bottom:3px solid transparent;color:#263a31}
.main-nav a:hover,.main-nav a.active{color:var(--green-2);border-color:var(--green-2)}
.header-cta,.primary-btn{
  display:inline-flex;align-items:center;gap:9px;border-radius:999px;
  background:linear-gradient(135deg,#63b65c,#2f8c45);
  color:white;font-weight:800;padding:15px 26px;box-shadow:0 12px 28px rgba(63,155,78,.28);
  white-space:nowrap;
}
.header-cta{flex-shrink:0}
.header-cta-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:18px;
  height:18px;
}
.header-cta-icon svg{
  width:100%;
  height:100%;
  display:block;
  stroke:currentColor;
  fill:none;
  stroke-width:1.8;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.menu-toggle{display:none;background:none;border:0;width:42px}
.menu-toggle span{display:block;height:3px;background:var(--green);margin:7px 0;border-radius:4px}

.hero{
  position: relative;
  overflow: visible;
}
.hero-bg-layers {
  position: absolute;
  inset: 0;
  width: 100vw;
  min-width: 100vw;
  height: 100%;
  pointer-events: none;
  z-index: 0;
}
.hero-bg-blob {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  opacity: 0.85;
  filter: blur(0.5px) drop-shadow(0 18px 60px rgba(18,75,50,.10));
}
.hero-bg-blob1 {
  top: -120px;
  width: 1200px;
  opacity: 0.7;
  animation: heroBlob1 22s ease-in-out infinite alternate;
}
.hero-bg-blob2 {
  top: 80px;
  width: 700px;
  opacity: 0.5;
  animation: heroBlob2 28s ease-in-out infinite alternate;
}
.hero-bg-blob3 {
  top: 220px;
  width: 420px;
  opacity: 0.4;
  animation: heroBlob3 32s ease-in-out infinite alternate;
}
.hero-float {
  position: absolute;
  z-index: 1;
  opacity: 0.92;
  filter: drop-shadow(0 8px 24px rgba(18,75,50,.10));
  animation: heroFloat 18s ease-in-out infinite alternate;
}
.hero-float.berry { animation-delay: 0s; }
.hero-float.leaf { animation-delay: 3s; }
.hero-float.heart { animation-delay: 6s; }
.hero-float.flower { animation-delay: 9s; }
@keyframes heroBlob1 {
  0% { transform: translateX(-50%) scale(1); }
  100% { transform: translateX(-50%) scale(1.04) translateY(18px); }
}
@keyframes heroBlob2 {
  0% { transform: translateX(-50%) scale(1); }
  100% { transform: translateX(-50%) scale(1.07) translateY(12px); }
}
@keyframes heroBlob3 {
  0% { transform: translateX(-50%) scale(1); }
  100% { transform: translateX(-50%) scale(1.12) translateY(-10px); }
}
@keyframes heroFloat {
  0% { transform: translateY(0) scale(1); }
  100% { transform: translateY(-18px) scale(1.04); }
}
.hero .container.hero-grid {
  position: relative;
  z-index: 2;
}

.hero-grid{display:grid;grid-template-columns:1fr 1.15fr;align-items:center;gap:44px;min-height:560px}
.hero-copy{position:relative}
.eyebrow{font-weight:800;color:var(--pink);font-size:26px;margin-bottom:12px}
h1,h2{font-family:"Playfair Display",Georgia,serif;color:var(--green);line-height:1.08}
h1{font-size:clamp(54px,8vw,90px);letter-spacing:-.04em;margin-bottom:20px}
h2{font-size:clamp(34px,4vw,50px)}
.hero-text{font-size:22px;max-width:560px;color:#2f443a;margin-bottom:28px}
.decor{position:absolute;z-index:-1;filter:drop-shadow(0 16px 30px rgba(18,75,50,.12))}
.decor svg{width:100%;height:100%;display:block}
.sun{top:-20px;right:140px;width:72px;height:72px}
.cloud{top:72px;right:20px;width:88px;height:56px}
.hero-badges{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;max-width:620px;margin-top:34px}
.hero-badge-card{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:12px;
  text-align:center;
  font-weight:700;
  font-size:13px;
}
.hero-badge-visual{
  position:relative;
  width:96px;
  height:96px;
  border-radius:28px;
  border:1px solid rgba(18,75,50,.08);
  box-shadow:0 18px 40px rgba(18,75,50,.12);
  display:grid;
  place-items:center;
  overflow:hidden;
  animation:badgeFloat 6s ease-in-out infinite alternate;
}
.hero-badge-visual::before{
  content:"";
  position:absolute;
  inset:14px 14px auto auto;
  width:44px;
  height:44px;
  border-radius:999px;
  background:rgba(255,255,255,.55);
}
.hero-badge-visual.pink{
  background:linear-gradient(180deg,#fff8fa,#ffe8ed);
}
.hero-badge-visual.green{
  background:linear-gradient(180deg,#f7fff8,#e8f3dc);
}
.hero-badge-visual.yellow{
  background:linear-gradient(180deg,#fffdf5,#fff1c7);
}
.hero-badge-visual svg{
  width:78px;
  height:78px;
  display:block;
  position:relative;
  z-index:1;
}
@keyframes badgeFloat {
  0% { transform: translateY(0) rotate(-0.5deg); }
  100% { transform: translateY(-8px) rotate(0.5deg); }
}

.hero-media{position:relative}
.blob-shape{
  height:540px;
  border-radius:36% 64% 56% 44% / 42% 24% 76% 58%;
  overflow:hidden;
  background:
    radial-gradient(circle at 30% 25%,rgba(255,255,255,.8),transparent 22%),
    linear-gradient(135deg,#d5edd6,#fff0d8 55%,#e0f2d2);
  box-shadow:var(--shadow);
}
.blob-shape img{width:100%;height:100%;object-fit:cover}
.blob-shape.placeholder:after{
  content:"Снимка на детската градина";
  height:100%;display:grid;place-items:center;color:#52715f;font-weight:800;font-size:22px
}
.leaf{position:absolute;font-size:42px;background:rgba(232,242,223,.78);border-radius:48% 52% 44% 56%;padding:20px}
.leaf.one{right:5%;bottom:-20px}
.leaf.two{right:-15px;bottom:50px}
.leaf.three{left:40px;bottom:10px;background:transparent}

.centered{text-align:center}
.section-heading{margin-bottom:38px}
.heart-line{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;margin-top:8px;position:relative;vertical-align:middle}
.heart-line svg{width:100%;height:100%;display:block;filter:drop-shadow(0 8px 18px rgba(242,94,129,.2))}
.heart-line:before,.heart-line:after{content:"";position:absolute;top:50%;width:42px;height:2px;background:#ffd0d2}
.heart-line:before{right:34px}.heart-line:after{left:34px}

.cards-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:20px}
.feature-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.daily-card,.feature-grid article,.doc-card{
  background:rgba(255,255,255,.76);
  border:1px solid rgba(18,75,50,.08);
  border-radius:22px;
  padding:34px 24px;
  box-shadow:0 16px 40px rgba(18,75,50,.08);
  transition:.25s ease;
}
.daily-card:hover,.feature-grid article:hover,.doc-card:hover{transform:translateY(-6px);box-shadow:0 24px 55px rgba(18,75,50,.13)}
.daily-card{text-align:center}
.daily-card h3,.feature-grid h3,.doc-card h3{color:var(--green);font-size:18px;margin:16px 0 10px}
.daily-card p,.feature-grid p,.doc-card p{color:var(--muted)}
.icon{width:78px;height:78px;border-radius:50%;display:grid;place-items:center;margin:0 auto 18px;position:relative;overflow:hidden;box-shadow:0 18px 34px rgba(18,75,50,.12);transition:transform .25s ease, box-shadow .25s ease}
.icon::before{content:"";position:absolute;inset:10px 10px auto auto;width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,.55)}
.icon svg{width:34px;height:34px;display:block;z-index:1;filter:drop-shadow(0 10px 18px rgba(18,75,50,.12))}
.daily-card:hover .icon{transform:translateY(-2px)}
.pink{background:linear-gradient(180deg,#fff7f8,#ffe7ea);color:#b54662}
.green{background:linear-gradient(180deg,#f6fff3,#e3f2dc);color:#2f7d49}
.yellow{background:linear-gradient(180deg,#fffdf4,#fff0c7);color:#9c6a13}
.blue{background:linear-gradient(180deg,#f4fbff,#dff1ff);color:#1a6f8f}

.section-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px;gap:20px}
.outline-btn{display:inline-flex;align-items:center;gap:9px;border:1.5px solid rgba(18,75,50,.28);border-radius:999px;color:var(--green);font-weight:800;padding:12px 20px;background:white}
.outline-btn:hover{background:var(--soft-green)}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.gallery-grid figure{height:190px;border-radius:18px;overflow:hidden;background:linear-gradient(135deg,#e8f2df,#fff0d8);box-shadow:var(--shadow)}
.gallery-grid img{width:100%;height:100%;object-fit:cover;transition:.35s ease;cursor:zoom-in}
.gallery-grid figure:hover img{transform:scale(1.08)}
.image-placeholder:after{content:"Снимка";height:100%;display:grid;place-items:center;color:#50705d;font-weight:800}

.gallery-lightbox{
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  padding:16px;
  z-index:50;
}

.gallery-lightbox.is-open{
  display:flex;
}

.gallery-lightbox__backdrop{
  position:absolute;
  inset:0;
  background:rgba(11,22,16,.8);
  backdrop-filter:blur(3px);
}

.gallery-lightbox__dialog{
  position:relative;
  z-index:1;
  width:min(100%, 1100px);
  max-height:calc(100vh - 32px);
  display:flex;
  align-items:center;
  justify-content:center;
}

.gallery-lightbox__image{
  width:100%;
  height:min(84vh, 720px);
  object-fit:contain;
  border-radius:24px;
  background:rgba(255,255,255,0.02);
  box-shadow:0 30px 90px rgba(0,0,0,.35);
}

.gallery-lightbox__close{
  position:absolute;
  top:12px;
  right:12px;
  width:44px;
  height:44px;
  border:0;
  border-radius:999px;
  background:rgba(255,255,255,.92);
  color:var(--green);
  font-size:28px;
  line-height:1;
  cursor:pointer;
  box-shadow:0 12px 30px rgba(0,0,0,.2);
}

body.gallery-lightbox-open{
  overflow:hidden;
}

@media (max-width:620px){
  .gallery-grid{grid-template-columns:1fr}
  .gallery-lightbox{padding:12px}
  .gallery-lightbox__image{height:72vh;border-radius:18px}
  .gallery-lightbox__close{top:8px;right:8px;width:40px;height:40px;font-size:24px}
}

/* NEWS SECTION */
.news-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:28px;
  align-items:stretch;
}

.news-state{
  grid-column:1 / -1;
  padding:28px 24px;
  border-radius:24px;
  text-align:center;
  color:#385847;
  background:rgba(255,255,255,.82);
  border:1px solid rgba(18,75,50,.08);
  box-shadow:0 18px 45px rgba(35,65,47,.08);
  font-weight:700;
}

.news-loading-state{
  background:linear-gradient(135deg, rgba(255,255,255,.9), rgba(255,245,236,.92));
}

.news-error-state{
  color:#7a2b2b;
  background:rgba(255,243,243,.92);
  border-color:rgba(122,43,43,.16);
}

.news-card{
  background:rgba(255,255,255,.94);
  border-radius:28px;
  overflow:hidden;
  box-shadow:0 18px 40px rgba(18,75,50,.12);
  border:1px solid rgba(18,75,50,.08);
  transition:transform .25s ease, box-shadow .25s ease;
  display:flex;
  flex-direction:column;
}

.news-card:hover{
  transform:translateY(-8px);
  box-shadow:0 28px 60px rgba(18,75,50,.16);
}

.news-image{
  position:relative;
  min-height:220px;
  overflow:hidden;
  background:linear-gradient(135deg,#a8d5ba,#7ac587);
  flex:0 0 auto;
}

.news-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.news-image--placeholder{
  display:grid;
  place-items:center;
  background:linear-gradient(135deg,#f7efe4,#f6f1e1 50%,#f6dfed 100%);
}

.news-placeholder-art{
  position:relative;
  width:100%;
  height:100%;
}

.news-placeholder-art::before,
.news-placeholder-art::after,
.news-placeholder-bubble,
.news-placeholder-leaf,
.news-placeholder-star{
  position:absolute;
  display:block;
  border-radius:999px;
}

.news-placeholder-art::before{
  content:"";
  inset:34px 40px auto auto;
  width:78px;
  height:78px;
  background:rgba(255,216,121,.38);
}

.news-placeholder-art::after{
  content:"";
  inset:auto auto 28px 24px;
  width:86px;
  height:86px;
  background:rgba(246,141,178,.22);
}

.news-placeholder-bubble{
  left:42px;
  top:50px;
  width:48px;
  height:48px;
  background:rgba(255,255,255,.78);
}

.news-placeholder-leaf{
  right:36px;
  bottom:30px;
  width:74px;
  height:42px;
  border-radius:60% 40% 60% 40%;
  background:rgba(127,195,138,.35);
  transform:rotate(-8deg);
}

.news-placeholder-star{
  right:54px;
  top:36px;
  width:30px;
  height:30px;
  background:rgba(255,248,216,.9);
  transform:rotate(16deg);
}

.news-content{
  padding:24px 24px 26px;
  flex:1;
  display:flex;
  flex-direction:column;
  gap:12px;
}

.news-date{
  font-size:13px;
  font-weight:800;
  color:var(--pink);
  text-transform:uppercase;
  letter-spacing:.05em;
}

.news-card h3{
  font-size:20px;
  color:var(--green);
  line-height:1.3;
}

.news-card p{
  font-size:15px;
  color:var(--muted);
  line-height:1.7;
  flex:1;
}

.news-card-footer{
  margin-top:auto;
  display:flex;
  align-items:center;
  justify-content:flex-start;
}

.read-more{
  color:var(--green-2);
  font-weight:700;
  font-size:14px;
  display:inline-flex;
  align-items:center;
  gap:6px;
  transition:color .25s ease, transform .25s ease;
}

.read-more:hover{color:var(--green);transform:translateX(4px)}

.read-more--disabled{
  color:rgba(35,75,53,.55);
  pointer-events:none;
}

.docs-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:22px}
.doc-card{display:flex;gap:18px;align-items:flex-start;padding:26px 20px}
.pdf-icon{width:48px;height:58px;border-radius:10px;display:grid;place-items:center;color:white;font-size:25px;flex:0 0 auto}
.pdf-icon.green{background:#2f9a54}.pdf-icon.red{background:#f06d73}.pdf-icon.yellow{background:#f1b821}.pdf-icon.blue{background:#2e9adc}
.doc-card a{display:inline-block;margin-top:16px;color:#0f7d3a;font-weight:800}
.docs-btn{margin:28px auto 0;width:max-content}

.contact-footer{position:relative;background:#e7f1dc;padding-top:85px;color:var(--green);overflow:hidden}
.wave{position:absolute;top:-50px;left:-5%;width:110%;height:110px;background:var(--cream);border-radius:0 0 50% 50%}
.contact-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;position:relative;z-index:1;margin-bottom:44px}
.footer-section{display:flex;flex-direction:column;gap:14px}
.footer-section h3{
  font-size:18px;
  font-weight:700;
  color:#234b35;
  margin-bottom:8px;
}
.footer-section p{
  font-size:15px;
  color:#385847;
  line-height:1.7;
}
.footer-brand h3{
  font-family:"Playfair Display",Georgia,serif;
  font-size:22px;
  line-height:1.2;
}
.footer-brand p{
  color:#385847;
  font-size:14px;
}
.footer-brand .flower-logo{margin-bottom:8px}

.contact-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:28px;
  height:28px;
  border-radius:999px;
  background:rgba(255,255,255,.72);
  box-shadow:0 8px 18px rgba(18,75,50,.08);
  flex:0 0 auto;
  color:var(--green-2);
  margin-right:8px;
}
.contact-icon svg{
  width:16px;
  height:16px;
  display:block;
  stroke:currentColor;
  fill:none;
  stroke-width:1.8;
  stroke-linecap:round;
  stroke-linejoin:round;
}

.contact-links p{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:12px;
  min-width:0;
}
.contact-links a{
  color:#234b35;
  font-weight:600;
  transition:.2s ease;
  cursor:pointer;
}
.contact-links a:hover{
  color:var(--green-2);
  text-decoration:underline;
}
.contact-links strong{
  color:#234b35;
  font-weight:700;
  flex-shrink:0;
}
.director-line{
  display:flex;
  align-items:center;
  gap:10px;
  white-space:nowrap;
  width:100%;
}
.director-name{
  display:inline-block;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  min-width:0;
}

.map-shell{margin-top:32px}
.map-cards-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:20px;
}
.map-card{
  background:rgba(255,255,255,.65);
  border:1px solid rgba(18,75,50,.14);
  border-radius:24px;
  box-shadow:0 18px 45px rgba(35,65,47,.08);
  overflow:hidden;
}
.map-card-copy{
  padding:18px 18px 12px;
}
.map-card-label{
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:0.04em;
  color:var(--green-2);
  margin-bottom:6px;
}
.map-card-copy h3{
  font-size:16px;
  line-height:1.35;
  color:#234b35;
}
.map-frame{
  overflow:hidden;
  aspect-ratio: 16 / 10;
  border-top:1px solid rgba(18,75,50,.08);
}
.map-frame iframe{
  width:100%;
  height:100%;
  border:0;
  display:block;
}
.footer-bottom{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:18px;
  border-top:1px solid rgba(18,75,50,.15);
  padding:22px 0;
  margin-top:34px;
  font-size:14px;
}
.footer-bottom-copy p{
  color:#385847;
}
.footer-bottom-right{
  display:flex;
  align-items:center;
  gap:20px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.socials{display:flex;gap:16px;font-weight:900;font-size:20px}
.socials a{
  color:var(--green-2);
  transition:.2s ease;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:40px;
  height:40px;
  background:transparent;
  border-radius:0;
  outline:none;
  box-shadow:none;
  font-size:15px;
}
.socials a.facebook-link{
  min-width:0;
  height:auto;
  padding:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
  font-weight:800;
}
.socials a:hover{
  color:var(--green);
  transform:translateY(-1px);
}
.footer-credit{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:rgba(35,75,53,0.9);
  font-size:13.5px;
  font-weight:600;
  letter-spacing:0.02em;
  padding:7px 12px;
  border-radius:999px;
  background:rgba(255,255,255,0.62);
  border:1px solid rgba(18,75,50,0.08);
  transition:color .2s ease, background .2s ease, transform .2s ease, border-color .2s ease;
}
.footer-credit-label{
  font-size:12.4px;
  font-weight:500;
  color:rgba(35,75,53,0.75);
}
.footer-credit-brand{
  font-size:13.8px;
  font-weight:800;
  color:rgba(35,75,53,1);
  letter-spacing:0.02em;
}
.footer-credit:hover{
  color:rgba(35,75,53,1);
  background:rgba(255,255,255,0.9);
  border-color:rgba(63,155,78,0.22);
  transform:translateY(-1px);
}

@media (max-width:980px){
  .menu-toggle{display:block}
  .main-nav{
    position:absolute;top:88px;left:24px;right:24px;background:white;border-radius:20px;
    flex-direction:column;align-items:flex-start;gap:0;padding:16px;box-shadow:var(--shadow);
    opacity:0;visibility:hidden;transform:translateY(-10px);transition:.25s ease
  }
  .main-nav.open{opacity:1;visibility:visible;transform:translateY(0)}
  .main-nav a{padding:13px 8px;width:100%;border-bottom:1px solid #edf2eb}
  .header-cta{display:none}
  .hero-grid{grid-template-columns:1fr}
  .hero-media{order:-1}.blob-shape{height:420px}
  .cards-grid,.feature-grid,.docs-grid,.gallery-grid,.news-grid{grid-template-columns:repeat(2,1fr)}
  .contact-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:620px){
  .container{width:min(100% - 24px,1120px)}
  .section{padding:58px 0}
  .nav-wrap{height:76px}
  .brand-text{font-size:15px}.brand-text em{font-size:15px}.flower-logo{width:42px;height:42px;transform:scale(.78)}
  .main-nav{top:76px;left:14px;right:14px}

  .hero{padding-top:18px}
  .hero-grid{gap:24px}
  .blob-shape{height:280px}
  .eyebrow{font-size:18px; margin-bottom:8px}
  h1{font-size:clamp(38px,10vw,46px); margin-bottom:14px}
  h2{font-size:30px}
  .hero-text{font-size:17px; line-height:1.65; margin-bottom:22px}

  .sun{width:56px;height:56px;top:-10px;right:86px}
  .cloud{width:72px;height:46px;top:56px;right:4px}

  .hero-badges{grid-template-columns:1fr; gap:14px; max-width:100%}
  .hero-badge-card{flex-direction:row; gap:14px; align-items:center; justify-content:flex-start; text-align:left}
  .hero-badge-visual{width:74px;height:74px; flex-shrink:0}
  .hero-badge-visual svg{width:62px;height:62px}
  .hero-badge-card p{font-size:14px; line-height:1.4}

  .section-heading{margin-bottom:24px}
  .section-row,.footer-bottom,.footer-bottom-right{align-items:flex-start;flex-direction:column}
  .section-row{gap:14px}
  .outline-btn{width:100%; justify-content:center}

  .cards-grid,.feature-grid,.docs-grid,.gallery-grid,.news-grid,.contact-grid,.map-cards-grid{grid-template-columns:1fr; gap:16px}
  .atelier-card{padding:22px 18px}
  .atelier-card h3{font-size:1.1rem}
  .atelier-card p{font-size:1rem}

  .gallery-grid figure{height:auto; aspect-ratio:4 / 3}

  .news-image{min-height:180px}
  .news-content{padding:20px 18px 22px; gap:10px}
  .news-card h3{font-size:18px}
  .news-card p{font-size:14.5px}

  .news-state{padding:22px 18px}

  .documents-grid{padding:0; gap:14px}
  .doc-tile{min-height:200px; padding:16px}
  .doc-icon{width:40px;height:42px}
  .doc-tile strong{font-size:15px}
  .doc-tile p{font-size:13px; margin:8px 0 12px}
  .doc-action{width:100%; justify-content:center}

  .contact-footer{padding-top:56px}
  .contact-grid{gap:20px}
  .footer-section{gap:12px}
  .footer-brand h3{font-size:20px}
  .contact-icon{width:26px;height:26px}
  .contact-links p{align-items:flex-start; flex-wrap:wrap}
  .director-line{white-space:normal; align-items:flex-start}
  .footer-bottom{padding:18px 0; gap:14px}
  .footer-bottom-right{gap:10px; width:100%}
  .footer-legal-links{display:grid; gap:6px}
  .footer-legal-divider{display:none}
  .footer-credit{width:100%; justify-content:flex-start}

  .section-decorations .decor-element{opacity:.3; transform:scale(.8)}
}

.legal-page {
  padding-top: 40px;
  padding-bottom: 70px;
}

.legal-shell {
  max-width: 860px;
  background: rgba(255,255,255,0.82);
  border-radius: 30px;
  box-shadow: 0 20px 45px rgba(18,75,50,0.1);
  border: 1px solid rgba(18,75,50,0.08);
  padding: 40px 36px;
}

.legal-shell .eyebrow {
  font-size: 18px;
  margin-bottom: 12px;
}

.legal-shell h1 {
  font-size: clamp(32px, 4vw, 42px);
  margin-bottom: 18px;
}

.legal-intro {
  font-size: 1.04rem;
  color: #2f443a;
  margin-bottom: 16px;
}

.legal-shell p,
.legal-shell li {
  line-height: 1.85;
  color: #2f443a;
}

.legal-shell ul {
  margin: 18px 0 18px 20px;
  padding-left: 8px;
}

.legal-note {
  margin-top: 24px;
  padding-top: 18px;
  border-top: 1px solid rgba(18,75,50,0.12);
}

.mail-link {
  color: var(--green-2);
  font-weight: 800;
}

.footer-legal-links {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.footer-legal-link {
  color: rgba(35,75,53,0.92);
  font-weight: 700;
  padding: 6px 10px;
  border-radius: 999px;
  transition: background-color .2s ease, color .2s ease, transform .2s ease;
}

.footer-legal-link:hover {
  color: rgba(35,75,53,1);
  background: rgba(255,255,255,0.78);
  transform: translateY(-1px);
}

.footer-legal-divider {
  color: rgba(35,75,53,0.35);
}

.documents-grid {
  max-width: 1160px;
  margin: 24px auto 0;
  padding: 0 20px;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
  justify-content: center;
  align-items: stretch;
  grid-auto-rows: 1fr;
}

.doc-tile {
  min-height: 228px;
  background: linear-gradient(180deg, #fffdf8 0%, #fff 100%);
  border: 1px solid rgba(46, 93, 63, 0.12);
  border-radius: 22px;
  padding: 18px 18px 16px;
  text-decoration: none;
  color: #174b32;
  box-shadow: 0 14px 36px rgba(35, 65, 47, 0.08);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
  height: 100%;
}

.doc-tile:hover {
  transform: translateY(-4px);
  box-shadow: 0 20px 46px rgba(35, 65, 47, 0.12);
  border-color: rgba(76, 166, 88, 0.32);
}

.doc-icon {
  width: 44px;
  height: 46px;
  border-radius: 14px;
  background: #eaf6df;
  color: #3f9b4a;
  display: grid;
  place-items: center;
  font-weight: 800;
  letter-spacing: 0.04em;
  font-size: 13px;
}

.doc-tile strong {
  font-size: 16px;
  line-height: 1.25;
  display: block;
  margin-top: 12px;
}

.doc-category {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 10px;
  padding: 5px 10px;
  border-radius: 999px;
  background: #eaf6df;
  color: #2f8c45;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: 11px;
}

.doc-tile p {
  margin: 10px 0 14px;
  color: #5f6f65;
  line-height: 1.6;
  font-size: 13.5px;
  flex: 1;
}

.doc-action {
  margin-top: auto;
  align-self: flex-start;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 999px;
  background: linear-gradient(135deg, #63b65c, #2f8c45);
  color: #fff;
  font-weight: 800;
  box-shadow: 0 12px 24px rgba(63, 155, 78, 0.22);
  font-size: 13px;
}

.documents-state {
  grid-column: 1 / -1;
  padding: 24px 28px;
  border-radius: 24px;
  background: rgba(255,255,255,.75);
  border: 1px dashed rgba(18,75,50,.18);
  color: #385847;
  text-align: center;
  font-weight: 700;
  box-shadow: 0 18px 45px rgba(35, 65, 47, 0.08);
}

.documents-state--error {
  color: #7a2b2b;
  background: rgba(255,243,243,.9);
  border-color: rgba(122,43,43,.2);
}

@media (max-width: 900px) {
  .documents-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 560px) {
  .documents-grid {
    grid-template-columns: 1fr;
  }
}

.cards-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 24px;
  margin-top: 44px;
}

@media (max-width: 980px) {
  .cards-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 22px;
  }
}

@media (max-width: 620px) {
  .cards-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }
}

.atelier-card {
  position: relative;
  background: var(--white);
  border-radius: var(--radius);
  box-shadow: 0 8px 32px rgba(23,67,43,.10);
  padding: 30px 22px 26px 22px;
  overflow: hidden;
  transition: box-shadow .22s, transform .22s;
  z-index: 1;
}
.atelier-card:hover {
  box-shadow: 0 18px 48px rgba(23,67,43,.16);
  transform: translateY(-4px) scale(1.025);
}
.atelier-card-blob {
  position: absolute;
  z-index: 0;
  top: -38px;
  left: -38px;
  width: 140px;
  height: 140px;
  border-radius: 50%;
  opacity: 0.22;
  filter: blur(2px);
  background: linear-gradient(135deg, #f68db2 0%, #ffe7eb 100%);
  transition: opacity .22s;
}
.atelier-card-pink .atelier-card-blob {
  background: linear-gradient(135deg, #f68db2 0%, #ffe7eb 100%);
}
.atelier-card-green .atelier-card-blob {
  background: linear-gradient(135deg, #7fc38a 0%, #e8f2df 100%);
}
.atelier-card-yellow .atelier-card-blob {
  background: linear-gradient(135deg, #ffd879 0%, #fff0c7 100%);
}
.atelier-card-blue .atelier-card-blob {
  background: linear-gradient(135deg, #80c8e9 0%, #dff1ff 100%);
}
.atelier-card-illu {
  position: relative;
  z-index: 1;
  margin-bottom: 18px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
}
.atelier-card h3 {
  font-size: 1.22rem;
  font-weight: 800;
  color: var(--green);
  margin-bottom: 10px;
  margin-top: 0;
}
.atelier-card p {
  color: var(--muted);
  font-size: 1.04rem;
  margin-bottom: 0;
}

.section-divider {
  position: relative;
  width: 100vw;
  min-width: 100vw;
  height: 120px;
  margin-top: -18px;
  margin-bottom: -18px;
  z-index: 2;
  pointer-events: none;
}
.section-divider .divider-bg {
  position: absolute;
  top: 0; left: 0; width: 100%; height: 120px;
  display: block;
  z-index: 1;
}
.section-divider .divider-motif {
  position: absolute;
  z-index: 2;
  opacity: 0.92;
  filter: drop-shadow(0 4px 16px rgba(18,75,50,.10));
  animation: dividerFloat 12s ease-in-out infinite alternate;
}
.section-divider .divider-motif.berry { animation-delay: 0s; }
.section-divider .divider-motif.leaf { animation-delay: 2s; }
.section-divider .divider-motif.heart { animation-delay: 4s; }
@keyframes dividerFloat {
  0% { transform: translateY(0) scale(1); }
  100% { transform: translateY(-10px) scale(1.04); }
}
