/* ─── Bloom Hours — Floral Boutique POP Theme ───────────────────────── */
:root{
  --bg:        #FFF7F2;
  --bg-2:      #FBE9E0;
  --bg-3:      #F5DAD0;
  --ink:       #4A3D33;
  --ink-2:     #6E5D52;
  --muted:     #B0A096;
  --line:      rgba(74,61,51,.12);
  --rose:      #E8748F;
  --rose-d:    #C95271;
  --green:     #7BA17D;
  --green-d:   #557E5A;
  --lav:       #B4A7D6;
  --beige:     #E8D5B7;
  --gold:      var(--rose);
  --border:    rgba(74,61,51,.12);
  --ff-en:     "Cormorant Garamond","Playfair Display",serif;
  --ff-disp:   "Cormorant Garamond","Playfair Display",serif;
  --ff-script: "Caveat","Brush Script MT",cursive;
  --ff-jp:     "Noto Serif JP","Yu Mincho",serif;
}
*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}
html,body{overflow-x:hidden}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--ff-jp);
  font-size:15px;line-height:1.95;
  -webkit-font-smoothing:antialiased;letter-spacing:.02em;
  padding-top:74px;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:.2s}
button{cursor:pointer;background:none;border:0;font-family:inherit;color:inherit}
.wrap{max-width:1200px;margin:0 auto;padding:0 6vw}

/* DEMO BAR */
#demo-bar{
  position:fixed;top:0;left:0;right:0;z-index:1200;
  background:var(--ink);padding:8px 0;color:#fff;
}
.demo-bar-inner{display:flex;align-items:center;justify-content:center;gap:10px;font-size:.7rem;font-weight:500}
.demo-badge{font-family:var(--ff-en);font-size:.6rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;background:var(--rose);color:#fff;padding:3px 10px;border-radius:99px}
.demo-link{color:var(--beige);text-decoration:underline;text-underline-offset:3px;font-weight:600}
.demo-copy{opacity:.55;font-size:.62rem;margin-left:6px}
@media(max-width:640px){.demo-copy{display:none}}

/* HEADER */
.site-header{
  position:fixed;top:36px;left:0;right:0;z-index:1100;
  background:rgba(255,247,242,.92);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
  padding:14px 6vw;display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.logo{display:flex;align-items:baseline;gap:4px;font-family:var(--ff-en);font-weight:600;font-size:1.7rem;color:var(--ink);letter-spacing:.01em;font-style:italic}
.logo .acc{color:var(--rose)}
.logo .sub{font-family:var(--ff-en);font-size:.62rem;font-weight:600;color:var(--green-d);letter-spacing:.22em;text-transform:uppercase;margin-left:8px;font-style:normal}
.header-nav{display:flex;align-items:center;gap:30px;font-family:var(--ff-en);font-weight:600;font-size:1rem;font-style:italic}
.header-nav a{color:var(--ink-2);position:relative;padding:6px 0}
.header-nav a:hover{color:var(--rose-d)}
.header-nav a:after{content:"";position:absolute;left:50%;bottom:-2px;width:0;height:2px;background:var(--rose);transition:.25s;transform:translateX(-50%)}
.header-nav a:hover:after{width:80%}
.btn-order{
  background:var(--rose);color:#fff;font-family:var(--ff-en);font-style:italic;font-weight:600;
  padding:11px 24px;border-radius:99px;font-size:.95rem;letter-spacing:.02em;
  box-shadow:0 4px 16px rgba(232,116,143,.35);transition:.2s;
}
.btn-order:hover{background:var(--rose-d);transform:translateY(-2px);box-shadow:0 8px 22px rgba(232,116,143,.45)}
.hamburger{display:none;width:42px;height:42px;border-radius:50%;background:var(--rose);color:#fff;align-items:center;justify-content:center;flex-direction:column;gap:5px;z-index:1101;position:relative}
.hamburger span{width:18px;height:2px;background:#fff;border-radius:2px;transition:.3s}
.hamburger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* HERO */
.hero{
  position:relative;padding:80px 6vw 120px;overflow:hidden;
  background:
    radial-gradient(ellipse at 25% 25%,rgba(232,116,143,.20) 0%,transparent 50%),
    radial-gradient(ellipse at 75% 75%,rgba(180,167,214,.18) 0%,transparent 50%),
    radial-gradient(ellipse at 50% 50%,rgba(123,161,125,.10) 0%,transparent 60%),
    var(--bg);
}
.hero-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center;max-width:1200px;margin:0 auto;position:relative;z-index:2}
.hero-eyebrow{font-family:var(--ff-script);font-size:1.6rem;color:var(--rose-d);margin-bottom:8px;line-height:1;transform:rotate(-2deg);display:inline-block}
.hero-title{
  font-family:var(--ff-en);font-weight:500;font-style:italic;
  font-size:clamp(3.2rem,7vw,6.4rem);line-height:.98;letter-spacing:-.01em;
  color:var(--ink);margin-bottom:20px;
}
.hero-title .em{color:var(--rose-d);font-weight:600}
.hero-title .green{color:var(--green-d)}
.hero-jp{font-family:var(--ff-jp);font-weight:600;font-size:1.05rem;color:var(--ink-2);margin-bottom:22px;letter-spacing:.04em}
.hero-desc{font-size:.95rem;color:var(--ink-2);max-width:520px;margin-bottom:34px;line-height:1.95}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.btn-prim{
  background:var(--rose);color:#fff;font-family:var(--ff-en);font-style:italic;font-weight:600;
  padding:18px 32px;border-radius:99px;font-size:1rem;letter-spacing:.02em;
  box-shadow:0 6px 20px rgba(232,116,143,.4);transition:.2s;
}
.btn-prim:hover{background:var(--rose-d);transform:translateY(-3px);box-shadow:0 10px 28px rgba(232,116,143,.5)}
.btn-out{
  background:#fff;color:var(--ink);font-family:var(--ff-en);font-style:italic;font-weight:600;
  padding:18px 32px;border-radius:99px;font-size:1rem;letter-spacing:.02em;
  border:1.5px solid var(--ink);transition:.2s;
}
.btn-out:hover{background:var(--ink);color:#fff}

/* HERO right — bouquet visual */
.hero-vis{position:relative;height:560px}
.flower{
  position:absolute;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--ff-en);font-style:italic;color:#fff;text-align:center;line-height:1.1;
  box-shadow:0 16px 30px rgba(0,0,0,.10),inset 0 -10px 16px rgba(0,0,0,.10),inset 0 8px 14px rgba(255,255,255,.4);
  animation:floaty 5s ease-in-out infinite;
}
.flower .lab{display:block;font-family:var(--ff-script);font-size:1rem;opacity:.95;margin-top:6px}
.flower.f1{width:240px;height:240px;background:radial-gradient(circle at 35% 30%,#F5A0B5,var(--rose));top:30px;left:25%;font-size:1.4rem}
.flower.f2{width:180px;height:180px;background:radial-gradient(circle at 35% 30%,#A7C9A9,var(--green));top:240px;left:5%;font-size:1.1rem}
.flower.f3{width:160px;height:160px;background:radial-gradient(circle at 35% 30%,#D4C8E8,var(--lav));top:60px;right:8%;font-size:1rem}
.flower.f4{width:140px;height:140px;background:radial-gradient(circle at 35% 30%,#F2E0C2,var(--beige));color:var(--ink);top:300px;right:18%;font-size:.9rem}
@keyframes floaty{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-16px) rotate(3deg)}}
.leaf{position:absolute;width:90px;height:30px;background:var(--green);border-radius:50% 0 50% 0;transform:rotate(45deg);animation:floaty 6s ease-in-out infinite}
.leaf.l1{top:200px;left:50%;background:var(--green-d);opacity:.7}
.leaf.l2{bottom:30px;left:35%;background:var(--green);opacity:.6;transform:rotate(-30deg);animation-delay:1s}
.dot-deco{position:absolute;font-family:var(--ff-script);color:var(--rose-d);font-size:1.3rem}
.dot-deco.d1{top:18%;right:-2%;transform:rotate(-15deg)}
.dot-deco.d2{bottom:8%;left:8%;color:var(--lav);transform:rotate(8deg)}

/* MARQUEE */
.marquee{background:var(--ink);color:var(--bg);padding:14px 0;overflow:hidden;font-family:var(--ff-en);font-style:italic;font-weight:500;font-size:1.4rem;letter-spacing:.05em;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.marquee-inner{display:flex;gap:36px;white-space:nowrap;animation:marquee 28s linear infinite}
.marquee-inner span{display:inline-flex;align-items:center;gap:14px}
.marquee-inner .star{color:var(--rose);font-family:var(--ff-script);font-size:1.6rem;font-style:normal}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* SECTION */
.section{padding:120px 0;position:relative}
.section-tag{
  display:inline-block;font-family:var(--ff-script);font-size:1.5rem;
  color:var(--rose-d);margin-bottom:8px;line-height:1;transform:rotate(-2deg);
}
.section-title{
  font-family:var(--ff-en);font-style:italic;font-weight:500;
  font-size:clamp(2.4rem,4.6vw,4rem);line-height:1.05;letter-spacing:-.01em;margin-bottom:14px;color:var(--ink);
}
.section-title .em{color:var(--rose-d);font-weight:600}
.section-title .green{color:var(--green-d)}
.section-lead{font-size:.95rem;color:var(--ink-2);max-width:600px;margin-bottom:50px;line-height:1.95}

/* BOUQUETS */
.bq-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.bq{
  background:#fff;border-radius:24px;overflow:hidden;
  border:1px solid var(--line);box-shadow:0 8px 24px rgba(0,0,0,.05);transition:.3s;
}
.bq:hover{transform:translateY(-8px);box-shadow:0 18px 40px rgba(0,0,0,.10);border-color:var(--rose)}
.bq .pic{
  height:300px;display:flex;align-items:center;justify-content:center;
  font-family:var(--ff-en);font-style:italic;color:#fff;font-size:1.6rem;
  text-shadow:0 3px 0 rgba(0,0,0,.10);position:relative;overflow:hidden;
}
.bq .pic:before{content:"";position:absolute;inset:20px;border:1px solid rgba(255,255,255,.5);border-radius:18px;pointer-events:none}
.bq.b1 .pic{background:radial-gradient(circle at 30% 30%,#F5A0B5,var(--rose) 70%)}
.bq.b2 .pic{background:radial-gradient(circle at 30% 30%,#D4C8E8,var(--lav) 70%)}
.bq.b3 .pic{background:radial-gradient(circle at 30% 30%,#A7C9A9,var(--green) 70%)}
.bq.b4 .pic{background:radial-gradient(circle at 30% 30%,#F2E0C2,var(--beige) 70%);color:var(--ink);text-shadow:none}
.bq.b5 .pic{background:radial-gradient(circle at 30% 30%,#FFD9C2,#FF9978 70%)}
.bq.b6 .pic{background:radial-gradient(circle at 30% 30%,#FFFFFF,#F0E5DA 70%);color:var(--ink);text-shadow:none}
.bq .info{padding:26px}
.bq .info h3{font-family:var(--ff-en);font-style:italic;font-weight:600;font-size:1.5rem;margin-bottom:6px;letter-spacing:-.01em}
.bq .info .ja{font-family:var(--ff-jp);font-size:.85rem;color:var(--ink-2);margin-bottom:12px}
.bq .info p{font-size:.85rem;color:var(--ink-2);line-height:1.85;margin-bottom:14px}
.bq .info .meta{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--line);padding-top:14px}
.bq .info .yen{font-family:var(--ff-en);font-style:italic;font-size:1.4rem;color:var(--rose-d);font-weight:600}
.bq .info .tag{font-family:var(--ff-en);font-size:.62rem;background:var(--bg-2);color:var(--ink);padding:4px 10px;border-radius:99px;letter-spacing:.14em;text-transform:uppercase;font-weight:600}

/* SUBS */
.sub-s{padding:120px 6vw;background:linear-gradient(180deg,var(--bg) 0%,var(--bg-2) 100%)}
.sub-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:50px}
.sub{background:#fff;border-radius:24px;padding:36px 30px;border:1px solid var(--line);box-shadow:0 8px 24px rgba(0,0,0,.04);transition:.25s;text-align:center}
.sub:hover{transform:translateY(-6px);border-color:var(--rose);box-shadow:0 16px 36px rgba(232,116,143,.18)}
.sub.featured{background:var(--rose);color:#fff;border-color:var(--rose)}
.sub.featured h3,.sub.featured .yen,.sub.featured .ja,.sub.featured p,.sub.featured ul li{color:#fff}
.sub.featured ul li:before{color:#fff}
.sub .badge{display:inline-block;font-family:var(--ff-en);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;background:var(--ink);color:#fff;padding:4px 10px;border-radius:99px;margin-bottom:16px;font-weight:600}
.sub.featured .badge{background:var(--ink);color:var(--rose)}
.sub h3{font-family:var(--ff-en);font-style:italic;font-weight:600;font-size:1.6rem;margin-bottom:8px}
.sub .ja{font-family:var(--ff-jp);font-size:.85rem;color:var(--ink-2);margin-bottom:18px}
.sub .yen{font-family:var(--ff-en);font-style:italic;font-size:2.6rem;color:var(--rose-d);font-weight:600;line-height:1}
.sub .yen .small{font-size:.95rem;color:var(--ink-2);font-style:normal;font-weight:400}
.sub ul{list-style:none;text-align:left;margin:24px 0;padding:0}
.sub ul li{font-size:.85rem;color:var(--ink-2);padding:6px 0 6px 24px;position:relative}
.sub ul li:before{content:"✿";position:absolute;left:0;color:var(--rose-d);font-size:.9rem;top:8px}

/* STORY */
.story-s{padding:120px 6vw}
.story-inner{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;max-width:1200px;margin:0 auto}
.story-vis{
  aspect-ratio:1;background:radial-gradient(circle at 30% 30%,#F5A0B5,var(--rose));
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;box-shadow:0 30px 60px rgba(232,116,143,.30);
}
.story-vis:before{content:"";position:absolute;inset:30px;border:1px solid rgba(255,255,255,.4);border-radius:50%;pointer-events:none}
.story-vis .text{font-family:var(--ff-en);font-style:italic;font-weight:600;color:#fff;font-size:1.6rem;text-align:center;letter-spacing:.04em;text-shadow:0 2px 0 rgba(0,0,0,.10);line-height:1.1}
.story-vis .text .big{font-size:5rem;display:block;margin-bottom:10px;line-height:1;font-weight:500}
.story-vis .text .sm{font-family:var(--ff-script);font-size:1.5rem;display:block;margin-top:14px;font-weight:400;text-shadow:none;font-style:normal}
.story-content h2{font-family:var(--ff-en);font-style:italic;font-weight:500;font-size:clamp(2rem,3.6vw,3rem);line-height:1.05;margin-bottom:24px;letter-spacing:-.01em}
.story-content h2 em{font-style:italic;color:var(--rose-d);font-weight:600}
.story-content p{font-size:.95rem;color:var(--ink-2);margin-bottom:18px;line-height:1.95}

/* INSTA */
.gram-s{padding:120px 6vw;background:var(--bg-2);text-align:center}
.gram-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;margin-top:50px}
.gram-grid .gi{
  aspect-ratio:1;border-radius:18px;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--ff-en);font-style:italic;color:#fff;font-size:.9rem;
  transition:.25s;cursor:pointer;
}
.gram-grid .gi:hover{transform:scale(1.05);box-shadow:0 8px 24px rgba(0,0,0,.15)}
.gram-grid .gi:nth-child(1){background:radial-gradient(circle at 30% 30%,#F5A0B5,var(--rose) 80%)}
.gram-grid .gi:nth-child(2){background:radial-gradient(circle at 30% 30%,#D4C8E8,var(--lav) 80%)}
.gram-grid .gi:nth-child(3){background:radial-gradient(circle at 30% 30%,#A7C9A9,var(--green) 80%)}
.gram-grid .gi:nth-child(4){background:radial-gradient(circle at 30% 30%,#F2E0C2,var(--beige) 80%);color:var(--ink)}
.gram-grid .gi:nth-child(5){background:radial-gradient(circle at 30% 30%,#FFD9C2,#FF9978 80%)}
.gram-grid .gi:nth-child(6){background:radial-gradient(circle at 30% 30%,#F5A0B5,var(--lav) 80%)}
.gram-grid .gi:nth-child(7){background:radial-gradient(circle at 30% 30%,#D4C8E8,var(--rose) 80%)}
.gram-grid .gi:nth-child(8){background:radial-gradient(circle at 30% 30%,#A7C9A9,var(--lav) 80%)}
.gram-grid .gi:nth-child(9){background:radial-gradient(circle at 30% 30%,#F5A0B5,var(--green) 80%)}
.gram-grid .gi:nth-child(10){background:radial-gradient(circle at 30% 30%,#F2E0C2,var(--rose) 80%);color:var(--ink)}
.gram-grid .gi:nth-child(11){background:radial-gradient(circle at 30% 30%,#A7C9A9,var(--rose) 80%)}
.gram-grid .gi:nth-child(12){background:radial-gradient(circle at 30% 30%,#D4C8E8,var(--green) 80%)}

/* NEWS */
.news-s{padding:120px 6vw}
.news-list{max-width:900px;margin:40px auto 0;background:#fff;border-radius:24px;border:1px solid var(--line);overflow:hidden;box-shadow:0 8px 24px rgba(0,0,0,.04)}
.news-item{display:grid;grid-template-columns:120px 90px 1fr;gap:20px;align-items:center;padding:24px 28px;border-bottom:1px solid var(--line)}
.news-item:last-child{border-bottom:0}
.news-item .date{font-family:var(--ff-en);font-style:italic;color:var(--ink-2);font-size:.95rem}
.news-item .cat{font-family:var(--ff-en);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;background:var(--rose);color:#fff;padding:5px 10px;border-radius:99px;text-align:center;font-weight:600}
.news-item .ttl{font-weight:600;color:var(--ink);font-size:.95rem;line-height:1.7}

/* CTA */
.cta-s{padding:130px 6vw;text-align:center;background:linear-gradient(135deg,var(--rose) 0%,var(--lav) 100%);position:relative;overflow:hidden;color:#fff}
.cta-s:before{content:"❀";position:absolute;top:10%;left:10%;font-size:9rem;opacity:.18;animation:floaty 5s ease-in-out infinite}
.cta-s:after{content:"❀";position:absolute;bottom:10%;right:10%;font-size:9rem;opacity:.18;animation:floaty 6s ease-in-out infinite reverse}
.cta-s .eyebrow{font-family:var(--ff-script);font-size:1.8rem;color:#fff;opacity:.9;margin-bottom:8px;display:block;line-height:1}
.cta-s h2{position:relative;font-family:var(--ff-en);font-style:italic;font-weight:500;font-size:clamp(2.6rem,5vw,4.4rem);line-height:1.05;margin-bottom:18px;letter-spacing:-.01em;text-shadow:0 4px 0 rgba(0,0,0,.10)}
.cta-s p{position:relative;font-size:1rem;margin-bottom:36px}

/* FOOTER */
.site-footer{background:var(--ink);color:#fff;padding:80px 6vw 30px}
.foot-inner{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:50px;max-width:1200px;margin:0 auto}
.foot-brand .logo{color:#fff;font-size:1.7rem;margin-bottom:14px}
.foot-brand p{font-size:.85rem;line-height:1.95;color:rgba(255,255,255,.7);margin-bottom:18px}
.foot-col h5{font-family:var(--ff-en);font-style:italic;font-weight:600;font-size:.85rem;letter-spacing:.18em;text-transform:uppercase;color:var(--rose);margin-bottom:18px}
.foot-col a{display:block;font-size:.88rem;color:rgba(255,255,255,.78);padding:5px 0}
.foot-col a:hover{color:var(--rose)}
.foot-col .info{font-size:.85rem;color:rgba(255,255,255,.7);line-height:1.95}
.foot-bottom{border-top:1px solid rgba(255,255,255,.10);margin-top:56px;padding-top:24px;display:flex;justify-content:space-between;font-size:.75rem;color:rgba(255,255,255,.5);font-family:var(--ff-en);font-style:italic}

/* PAGE GENERIC */
.page-hero{padding:90px 6vw 70px;background:linear-gradient(135deg,#FBE9E0 0%,#F5DAD0 100%);text-align:center;position:relative;overflow:hidden}
.page-hero h1{font-family:var(--ff-en);font-style:italic;font-weight:500;font-size:clamp(2.6rem,5vw,4rem);letter-spacing:-.01em;color:var(--ink)}
.page-hero p{margin-top:8px;color:var(--ink-2);font-family:var(--ff-script);font-size:1.3rem}
.page-body{padding:80px 6vw;max-width:900px;margin:0 auto}
.page-body h2{font-family:var(--ff-en);font-style:italic;font-weight:600;font-size:1.8rem;margin:40px 0 14px;color:var(--ink);position:relative;padding-left:18px}
.page-body h2:before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:4px;background:var(--rose);border-radius:2px}
.page-body p{margin-bottom:14px;color:var(--ink-2)}
.page-body ul{margin:0 0 18px 24px}
.page-body ul li{margin-bottom:6px;color:var(--ink-2)}

/* CONTACT FORM */
.form-card{max-width:680px;margin:0 auto;background:#fff;padding:40px;border-radius:24px;border:1px solid var(--line);box-shadow:0 16px 40px rgba(0,0,0,.06)}
.form-row{margin-bottom:22px}
.form-row label{display:block;font-family:var(--ff-en);font-style:italic;font-weight:600;font-size:.85rem;letter-spacing:.04em;color:var(--ink);margin-bottom:8px}
.form-row label .req{color:var(--rose-d);margin-left:6px;font-size:.7rem}
.form-row input,.form-row textarea,.form-row select{width:100%;padding:14px 18px;border:1px solid var(--line);border-radius:14px;font-family:inherit;font-size:.92rem;background:var(--bg-2);color:var(--ink);transition:.2s}
.form-row input:focus,.form-row textarea:focus,.form-row select:focus{outline:none;border-color:var(--rose);background:#fff}
.form-row textarea{resize:vertical;min-height:140px}
.form-submit{display:block;width:100%;padding:18px;background:var(--rose);color:#fff;font-family:var(--ff-en);font-style:italic;font-size:1.05rem;border-radius:99px;letter-spacing:.04em;font-weight:600;box-shadow:0 6px 20px rgba(232,116,143,.4);transition:.2s}
.form-submit:hover{background:var(--rose-d)}

/* NEWS ARCHIVE */
.news-archive{display:grid;gap:18px;max-width:780px;margin:0 auto}
.news-row{display:grid;grid-template-columns:120px 90px 1fr;gap:20px;background:#fff;padding:24px 26px;border-radius:18px;border:1px solid var(--line);box-shadow:0 4px 16px rgba(0,0,0,.04);align-items:center;transition:.2s}
.news-row:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(0,0,0,.08);border-color:var(--rose)}
.news-row .date{font-family:var(--ff-en);font-style:italic;color:var(--ink-2)}
.news-row .cat{font-family:var(--ff-en);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;background:var(--rose);color:#fff;padding:5px 10px;border-radius:99px;text-align:center;font-weight:600}

/* RESPONSIVE */
@media(max-width:920px){
  body{padding-top:78px}
  .header-nav,.btn-order{display:none}
  .hamburger{display:flex}
  .site-header{padding:12px 5vw;top:36px}
  .hero-inner{grid-template-columns:1fr;gap:40px}
  .hero-vis{height:380px;transform:scale(.85)}
  .bq-grid{grid-template-columns:1fr 1fr;gap:18px}
  .sub-grid{grid-template-columns:1fr;gap:18px}
  .story-inner{grid-template-columns:1fr;gap:40px}
  .gram-grid{grid-template-columns:repeat(3,1fr)}
  .foot-inner{grid-template-columns:1fr 1fr;gap:30px}
  .news-item,.news-row{grid-template-columns:90px 70px 1fr;gap:14px;padding:18px}
  .news-item .ttl,.news-row .ttl{font-size:.88rem}
  .header-nav{
    position:fixed;inset:0;flex-direction:column;justify-content:center;align-items:center;
    background:var(--bg);z-index:1000;
    transform:translateY(-100%);transition:transform .35s cubic-bezier(.7,0,.3,1);
    padding-top:80px;gap:20px;font-size:1.7rem;
  }
  .header-nav.active{transform:translateY(0);display:flex}
  .header-nav a{font-size:1.7rem;color:var(--ink)}
  .site-header.menu-active{background:var(--bg)!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important}
}
@media(max-width:560px){
  .bq-grid{grid-template-columns:1fr}
  .gram-grid{grid-template-columns:repeat(2,1fr)}
  .foot-inner{grid-template-columns:1fr}
  .news-item,.news-row{grid-template-columns:1fr;gap:8px}
  .news-item .date,.news-item .cat,.news-row .date,.news-row .cat{display:inline-block;margin-right:8px}
}
