.header { background:var(--gradient-hero); color:#fff; position:relative; overflow:hidden; }
.header-bar { padding:.75rem 1.25rem; position:sticky; top:0; z-index:60; backdrop-filter:none; transition:background .45s var(--ease), box-shadow .45s var(--ease), padding .45s var(--ease); }
.header-bar > .wrap { display:flex; align-items:center; justify-content:space-between; gap:1rem; }
.header-bar.stuck { background:rgba(255,255,255,.72); backdrop-filter:blur(10px); box-shadow:0 6px 24px -12px rgba(0,0,0,.15); padding:.55rem 1.1rem; }
.logo-img { height:46px; width:auto; display:block; transition:height .45s var(--ease); }
.header-bar.stuck .logo-img { height:38px; }
.logo-text { font-size:1.75rem; font-weight:700; letter-spacing:.5px; }
.nav-list { list-style:none; display:flex; gap:1.25rem; margin:0; padding:0; }
.nav-list a { color:#fff; font-weight:600; position:relative; }
.nav-list a:after { content:""; position:absolute; left:0; bottom:-4px; width:0; height:2px; background:var(--yellow); transition:width .35s var(--ease); }
.nav-list a:hover { text-decoration: none; }
.nav-list a:hover:after { width:100%; }
.nav-toggle { display:none; background:none; border:2px solid rgba(255,255,255,.4); color:#fff; padding:.55rem .85rem; border-radius:14px; font-weight:600; }
.header-actions { display:flex; gap:.5rem; align-items:center; }
.order-now { display:none; }
.header-bar.stuck .order-now { display:inline-flex; }
.contrast-toggle { background:var(--pink-dark); color:#fff; border:none; padding:.6rem .75rem; border-radius:50%; cursor:pointer; box-shadow:var(--shadow-sm); }
.contrast-toggle:hover { background:var(--yellow); color:#222; }
.contrast-toggle .icon { width:1.1rem; height:1.1rem; }
.hero { position:relative; padding:clamp(4.5rem,12vh,9rem) 1.25rem 6rem; }
.hero-bg { position:absolute; inset:0; overflow:hidden; }
.noise-layer { position:absolute; inset:0; width:100%; height:100%; opacity:.18; mix-blend-mode:overlay; }
.orb { position:absolute; width:420px; height:420px; background:radial-gradient(circle at 30% 30%, rgba(255,255,255,.6), rgba(255,255,255,0) 70%); filter:blur(60px); opacity:.35; animation: drift 22s linear infinite; }
.orb-a { top:-120px; left:-120px; }
.orb-b { bottom:-160px; right:-100px; animation-duration:30s; }
.orb-c { top:40%; left:55%; animation-duration:26s; }
@keyframes drift { 0%{ transform:translate(0,0);} 50%{ transform:translate(40px,-30px);} 100%{ transform:translate(0,0);} }
.hero-inner { position:relative; z-index:2; }
.floating-decor { position:absolute; inset:0; pointer-events:none; }
.leaf { position:absolute; animation: float 24s linear infinite; }
.leaf:nth-child(1){ top:12%; left:62%; animation-duration:32s; }
.leaf:nth-child(2){ bottom:14%; left:8%; animation-duration:28s; }
.leaf:nth-child(3){ top:58%; right:6%; animation-duration:30s; }
@keyframes float { 0%{ transform:translateY(0) rotate(0deg);} 50%{ transform:translateY(-40px) rotate(160deg);} 100%{ transform:translateY(0) rotate(360deg);} }

/* Featured Slider */
.featured .slider { position:relative; display:grid; grid-template-columns:auto 1fr auto; align-items:stretch; gap:.75rem; margin-top:1.75rem; }
.slides { position:relative; overflow:hidden; border-radius:var(--radius); }
.slide { min-height:200px; padding:2.5rem 2rem; background:var(--gradient-card); color:#fff; display:flex; flex-direction:column; justify-content:flex-end; gap:.6rem; position:absolute; inset:0; opacity:0; transform:translateX(12%); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.slide.current { opacity:1; transform:translateX(0); position:absolute; }
.slider-prev, .slider-next { background:var(--white); color:var(--pink-dark); border:none; padding:.85rem 1rem; font-weight:700; border-radius:14px; cursor:pointer; box-shadow:var(--shadow-sm); }
.slider-prev:hover, .slider-next:hover { transform:translateY(-3px); }

/* Menu Redesign */
.menu-header { display:flex; flex-wrap:wrap; justify-content:space-between; align-items:flex-end; gap:1.5rem; margin-bottom:2.75rem; }
.menu-header-left { display:flex; flex-direction:column; gap:.9rem; }
.menu-cats { display:flex; flex-wrap:wrap; gap:.65rem; justify-content:flex-end; }
.menu-cat { background:#fff; border:2px solid var(--pink-soft); color:var(--pink-dark-soft); font-weight:700; padding:.6rem .95rem; border-radius:14px; cursor:pointer; transition:background .35s var(--ease), color .35s var(--ease), box-shadow .35s var(--ease); }
.menu-cat:hover { background:var(--pink-soft); color:#3d2340; }
.menu-cat.active { background:var(--yellow); color:#fff; box-shadow:0 6px 18px -8px rgba(0,0,0,.28); border-color:var(--yellow); }
.menu-legend { display:flex; gap:.5rem; flex-wrap:wrap; }
.legend-item { font-size:.6rem; letter-spacing:.5px; font-weight:700; padding:.35rem .65rem; border-radius:50px; background:var(--pink-dark); color:#fff; box-shadow:0 3px 10px -4px rgba(0,0,0,.35); }
.legend-item.fav { background:var(--yellow); color:#222; }
.legend-item.spicy { background:var(--violet); }
.legend-item.veg { background:var(--leaf-mid); }

.menu-content { display:flex; flex-direction:column; gap:3.2rem; }
.menu-section { position:relative; padding-bottom:.5rem; }
.menu-heading { font-size:1.9rem; margin:0 0 1.25rem; position:relative; display:inline-flex; align-items:center; gap:.75rem; }
.menu-heading:after { content:""; height:5px; border-radius:3px; background:linear-gradient(90deg,var(--pink-soft),var(--yellow-soft)); width:110px; box-shadow:0 2px 8px -4px rgba(0,0,0,.25); }
.menu-list { list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:1.2rem; }
.menu-item { background:#fff; border:1px solid rgba(0,0,0,.07); padding:1rem 1rem 1.05rem; border-radius:16px; box-shadow:2px 3px 12px -3px rgba(0,0,0,.12), 12px 8px 24px -12px rgba(0,0,0,.18); position:relative; overflow:hidden; transform:perspective(1000px) rotateX(2deg) rotateY(-1deg); transition:transform .3s ease, box-shadow .3s ease; }
.menu-item:before { content:""; position:absolute; inset:0; /* Overlay uses softened pink + new green tint */ background:linear-gradient(95deg,rgba(247,169,207,.12),rgba(132,184,19,.14)); opacity:0; transition:opacity .45s var(--ease); }
.menu-item:hover { 
    transform:perspective(1000px) rotateX(0deg) rotateY(0deg);
    box-shadow:1px 1px 14px -4px rgba(0,0,0,.15), 8px 6px 28px -12px rgba(0,0,0,.2);
}
.menu-item:hover:before { opacity:1; }
.menu-item.fav { border:2px solid var(--pink-soft); }
.item-header { display:flex; justify-content:space-between; align-items:baseline; gap:1rem; }
.item-name { font-weight:700; font-size:1.05rem; }
.item-price { background:#fff; color:var(--pink-dark); border:2px solid var(--pink-dark); font-weight:700; padding:.4rem .75rem; border-radius:50px; font-size:.9rem; letter-spacing:.5px; box-shadow:0 2px 10px -4px rgba(0,0,0,.18); }
.menu-item.fav .item-price { background:var(--yellow-soft); color:#fff; border-color:var(--yellow-soft); }
.item-desc { margin:.45rem 0 0; font-size:.85rem; line-height:1.35; opacity:.9; }
.badge { position:static; display:inline-block; background:var(--pink-dark); color:#fff; font-size:.55rem; font-weight:700; padding:.28rem .55rem; border-radius:50px; letter-spacing:.5px; box-shadow:0 2px 6px -2px rgba(0,0,0,.25); margin:.5rem .35rem 0 0; }
.badge-fav { background:var(--yellow); color:#222; }
.badge-spicy { background:var(--violet); }
.badge-veg { background:var(--leaf-mid); }
.menu-item.veg .item-price { background:#fff; color:var(--leaf-mid); border-color:var(--leaf-mid); }
.menu-item.veg.fav .item-price { background:var(--yellow-soft); color:#fff; border-color:var(--yellow-soft); }

/* Arrange badges as a line under description */
.menu-item .item-desc + .badge, .menu-item .badge + .badge { margin-top:.5rem; }
.menu-item .badge:last-of-type { margin-right:.1rem; }

@media (max-width:980px){
  .menu-header { flex-direction:column; align-items:flex-start; }
  .menu-cats { justify-content:flex-start; }
}
@media (max-width:600px){
  .menu-heading { font-size:1.55rem; }
  .item-name { font-size:1rem; }
  .menu-cat { padding:.55rem .6rem; }
}

/* Schedule */
.schedule-list { list-style:none; padding:0; margin:1.2rem 0 0; display:grid; gap:.55rem; }
.schedule-list li { background:#fff; border-left:6px solid var(--yellow-soft); padding:.6rem .85rem; border-radius:12px; box-shadow:var(--shadow-sm); }

/* Gallery */
.gallery .grid { display:grid; gap:1rem; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); margin-top:1.5rem; }
.gallery .ph { background:#fff; border:2px dashed var(--pink-dark); padding:2.5rem .5rem; border-radius:14px; font-weight:700; text-align:center; color:var(--pink-dark); font-size:.95rem; opacity:.9; }

/* Story */
.story p { max-width:62ch; }
/* Story enhancements */
.story-lead { font-size:clamp(1rem,1.9vw,1.15rem); line-height:1.4; font-weight:600; }
.story-pillars { list-style:none; margin:2rem 0 2.5rem; padding:0; display:grid; gap:1.4rem; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); }
.pillar { background:#fff; border:2px solid var(--pink-soft); padding:1.05rem 1rem 1.2rem; border-radius:16px; box-shadow:0 6px 18px -10px rgba(0,0,0,.15); position:relative; overflow:hidden; }
.pillar:before { content:""; position:absolute; inset:0; background:linear-gradient(140deg,rgba(247,169,207,.18),rgba(132,184,19,.18)); opacity:0; transition:opacity .45s var(--ease); }
.pillar:hover:before { opacity:1; }
.pillar h3 { margin:.1rem 0 .55rem; font-size:1.05rem; letter-spacing:.5px; }
.pillar p { font-size:.8rem; line-height:1.35; margin:0; }
.story-timeline { display:grid; gap:.9rem; margin:1.2rem 0 2.2rem; }
.milestone { background:#fff; border-left:6px solid var(--yellow); padding:.65rem .85rem .7rem; border-radius:12px; box-shadow:var(--shadow-sm); display:flex; flex-direction:column; gap:.35rem; }
.milestone .year { font-weight:700; font-size:.75rem; letter-spacing:1px; text-transform:uppercase; color:var(--pink-dark); }
.milestone p { margin:0; font-size:.78rem; line-height:1.35; }
.founder-note { margin:0 0 2.3rem; background:linear-gradient(135deg,var(--pink-soft),var(--yellow-soft)); padding:1.25rem 1.35rem 1.4rem; border-radius:20px; color:#222; font-weight:600; box-shadow:0 10px 32px -18px rgba(0,0,0,.25); position:relative; }
.founder-note p { margin:0 0 .75rem; font-size:1rem; line-height:1.35; }
.founder-note cite { font-style:normal; font-weight:700; letter-spacing:.6px; font-size:.75rem; opacity:.85; }
.story-cta { margin-top:.4rem; }
/* Story layout with media */
.story-layout { display:grid; gap:3rem; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); align-items:start; }
.story-text { display:flex; flex-direction:column; gap:1.1rem; }
.story-media { margin:0; position:relative; align-self:stretch; }
.story-img { width:100%; height:100%; object-fit:cover; border-radius:24px; box-shadow:0 16px 48px -18px rgba(0,0,0,.35), 0 4px 18px -6px rgba(0,0,0,.25); aspect-ratio:4/3; border:4px solid rgba(255,255,255,.65); background:linear-gradient(135deg,var(--pink-soft),var(--yellow-soft)); }
@media (max-width:760px){
  .story-layout { gap:2rem; }
  .story-img { aspect-ratio:16/10; }
}
@media (prefers-reduced-motion:reduce){
  .story-img { box-shadow:0 8px 28px -12px rgba(0,0,0,.35); }
}
@media (max-width:700px){
  .story-pillars { grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); }
  .pillar h3 { font-size:.95rem; }
  .pillar p { font-size:.72rem; }
  .milestone p { font-size:.72rem; }
}

/* Contact (redesigned to match card aesthetic) */
.contact-lead { font-size:clamp(.95rem,1.8vw,1.05rem); font-weight:600; line-height:1.35; max-width:60ch; margin:.6rem 0 1.6rem; }
.contact-layout { display:grid; gap:2.2rem; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); }
.contact-options { list-style:none; margin:0; padding:0; display:grid; gap:1rem; }
.contact-item { background:#fff; border:1px solid rgba(0,0,0,.07); padding:.85rem .9rem .95rem; border-radius:16px; box-shadow:0 4px 18px -8px rgba(0,0,0,.18); display:flex; align-items:flex-start; gap:.85rem; position:relative; overflow:hidden; }
.contact-item:before { content:""; position:absolute; inset:0; background:linear-gradient(95deg,rgba(247,169,207,.10),rgba(132,184,19,.12)); opacity:0; transition:opacity .45s var(--ease); }
.contact-item:hover:before { opacity:1; }
.contact-icon { font-size:1.4rem; line-height:1; }
.contact-icon .icon { width:1.25rem; height:1.25rem; color:var(--pink-dark); }
.contact-body { display:flex; flex-direction:column; gap:.3rem; }
.contact-label { font-size:.6rem; letter-spacing:1px; font-weight:700; text-transform:uppercase; color:var(--pink-dark); }
.contact-value { font-weight:700; color:#222; text-decoration:none; font-size:.95rem; }
.contact-value:hover { text-decoration:underline; }
.booking-card { background:#fff; border:1px solid rgba(0,0,0,.07); border-radius:16px; padding:1rem 1rem 1.1rem; box-shadow:0 4px 18px -8px rgba(0,0,0,.18); display:flex; flex-direction:column; gap:.75rem; position:relative; overflow:hidden; }
.booking-card:before { content:""; position:absolute; inset:0; background:linear-gradient(95deg,rgba(247,169,207,.10),rgba(132,184,19,.12)); opacity:0; transition:opacity .45s var(--ease); }
.booking-card:hover:before { opacity:1; }
.booking-card h3 { margin:0 0 .5rem; font-size:1.15rem; letter-spacing:.6px; font-weight:700; position:relative; display:inline-flex; align-items:center; gap:.6rem; }
.booking-card h3:after { content:""; height:5px; width:90px; background:linear-gradient(90deg,var(--pink-soft),var(--yellow-soft)); border-radius:3px; box-shadow:0 2px 8px -4px rgba(0,0,0,.25); }
.booking-text { margin:0; font-size:.9rem; line-height:1.5; opacity:.92; }
.booking-list { list-style:none; margin:.2rem 0 .4rem; padding:0; display:flex; flex-wrap:wrap; gap:.45rem; }
.booking-list li { background:var(--pink-dark); color:#fff; font-size:.65rem; font-weight:700; letter-spacing:.6px; padding:.4rem .7rem; border-radius:50px; box-shadow:0 2px 6px -2px rgba(0,0,0,.25); }
.booking-cta { margin-top:.3rem; padding:.7rem 1.15rem; font-size:.85rem; }
@media (max-width:640px){
  .booking-card h3 { font-size:1.05rem; }
  .booking-text { font-size:.85rem; }
}
@media (max-width:640px){ .contact-layout { gap:1.8rem; } .contact-item { padding:.75rem .8rem .85rem; } .contact-icon { font-size:1.2rem; } }
@media (max-width:640px){ .panel-title { font-size:.95rem; } }
.contact-info ul { list-style:none; margin:0; padding:0; display:grid; gap:.55rem; }
.contact-form .field { display:flex; flex-direction:column; gap:.35rem; margin-bottom:1rem; }
.contact-form input, .contact-form textarea { border:2px solid var(--pink-dark); padding:.65rem .75rem; border-radius:12px; background:#fff; color:#222; }
.contact-form input:focus, .contact-form textarea:focus { border-color:var(--yellow); }
.form-status { font-size:.85rem; margin-top:.5rem; min-height:1.1rem; }
/* Contact enhancements */
.contact-intro { max-width:60ch; font-weight:600; font-size:clamp(.95rem,1.8vw,1.05rem); line-height:1.4; margin:.6rem 0 1.2rem; }
.contact-cards { list-style:none; margin:0 0 1.4rem; padding:0; display:grid; gap:.8rem; }
.contact-card { background:#fff; border:2px solid var(--pink-soft); padding:.75rem .85rem .8rem; border-radius:14px; display:flex; flex-direction:column; gap:.25rem; position:relative; box-shadow:0 4px 18px -10px rgba(0,0,0,.15); }
.contact-card .label { font-size:.65rem; letter-spacing:1px; font-weight:700; text-transform:uppercase; color:var(--pink-dark); }
.contact-card .value { font-weight:700; font-size:.95rem; color:#222; word-break:break-word; }
.social-links { list-style:none; display:flex; gap:.55rem; padding:0; margin:0 0 1.5rem; }
.social-links a { background:#fff; width:46px; height:46px; display:flex; align-items:center; justify-content:center; border-radius:50%; box-shadow:0 4px 14px -6px rgba(0,0,0,.18); border:2px solid var(--pink-soft); font-size:1.25rem; transition:transform .35s var(--ease), background .35s var(--ease); }
.social-links a:hover { transform:translateY(-4px); background:var(--pink-soft); }
/* Legacy form/newsletter removed */
@media (max-width:640px){
  .action { padding:.6rem .65rem; }
  .action-text { font-size:.72rem; }
}
/* QR Card */
.qr-card { background:#fff; border:1px solid rgba(0,0,0,.07); padding:1rem .95rem 1.1rem; border-radius:16px; box-shadow:0 4px 18px -8px rgba(0,0,0,.18); display:flex; flex-direction:column; gap:.75rem; position:relative; overflow:hidden; }
.qr-card:before { content:""; position:absolute; inset:0; background:linear-gradient(105deg,rgba(247,169,207,.12),rgba(132,184,19,.14)); opacity:0; transition:opacity .45s var(--ease); }
.qr-card:hover:before { opacity:1; }
.qr-title { margin:0; font-size:1rem; letter-spacing:.5px; font-weight:700; display:inline-flex; align-items:center; gap:.6rem; position:relative; }
.qr-title:after { content:""; height:5px; width:70px; background:linear-gradient(90deg,var(--pink-soft),var(--yellow-soft)); border-radius:3px; box-shadow:0 2px 8px -4px rgba(0,0,0,.25); }
.qr-figure { margin:0; display:flex; align-items:center; justify-content:center; }
.qr-image { width:160px; height:160px; border:4px solid var(--pink-soft); border-radius:18px; background:#fff; box-shadow:0 10px 32px -18px rgba(0,0,0,.35),0 4px 14px -6px rgba(0,0,0,.25); }
.qr-note { margin:0; font-size:.72rem; line-height:1.35; opacity:.85; max-width:32ch; }
@media (max-width:780px){
  .qr-image { width:140px; height:140px; }
}
@media (max-width:640px){
  .qr-card { order:3; }
}
@media (prefers-reduced-motion:reduce){
  .qr-card:hover:before { opacity:.6; }
}

/* Footer */
/* Footer (Redesigned) */
.footer { position:relative; background:linear-gradient(130deg,var(--pink-dark) 0%, var(--pink-soft) 58%, var(--yellow-soft) 120%); color:#fff; padding:3.8rem 1.25rem 0; overflow:hidden; }
.footer:before, .footer:after { content:""; position:absolute; border-radius:50%; filter:blur(80px); opacity:.28; pointer-events:none; }
.footer:before { width:420px; height:420px; background:rgba(255,255,255,.38); top:-160px; left:-140px; }
.footer:after { width:300px; height:300px; background:rgba(255,255,255,.22); bottom:-120px; right:-90px; }
.footer-top-divider { position:absolute; left:50%; top:0; width:92%; height:4px; transform:translateX(-50%); background:linear-gradient(90deg,rgba(255,255,255,.15),rgba(255,255,255,.6),rgba(255,255,255,.15)); border-radius:4px; }
.footer-inner { display:grid; gap:2.5rem clamp(1rem,3vw,2.8rem); grid-template-columns:repeat(auto-fit,minmax(210px,1fr)); align-items:start; }
.footer-col { position:relative; }
.footer-brand { display:flex; flex-direction:column; gap:.75rem; max-width:300px; }
.footer-logo { width:78px; height:auto; border-radius:18px; box-shadow:0 10px 28px -12px rgba(0,0,0,.45); }
.footer-tagline { margin:0; font-size:.7rem; font-weight:700; letter-spacing:.7px; text-transform:uppercase; opacity:.8; }
.footer-mission { margin:.2rem 0 .4rem; font-size:.78rem; line-height:1.35; max-width:34ch; opacity:.9; }
.footer-social { display:flex; gap:.55rem; flex-wrap:wrap; margin-top:.4rem; }
.social-btn { width:44px; height:44px; display:flex; align-items:center; justify-content:center; background:#fff; color:var(--pink-dark); border-radius:50%; font-size:1.15rem; box-shadow:0 5px 18px -8px rgba(0,0,0,.3); text-decoration:none; border:2px solid rgba(0,0,0,.05); transition:transform .4s var(--ease), background .4s var(--ease), color .4s var(--ease); }
.social-btn .icon { width:1.2rem; height:1.2rem; }
.social-btn:hover { transform:translateY(-5px) rotate(-6deg); background:var(--yellow-soft); color:#222; }
.footer-title { margin:0 0 .85rem; font-size:.9rem; letter-spacing:.8px; font-weight:700; text-transform:uppercase; position:relative; display:inline-flex; align-items:center; gap:.5rem; }
.footer-title:after { content:""; height:4px; width:60px; background:linear-gradient(90deg,var(--pink-soft),var(--yellow-soft)); border-radius:3px; box-shadow:0 2px 6px -3px rgba(0,0,0,.35); }
.footer-nav { max-width:180px; }
.footer-list { list-style:none; margin:0; padding:0; display:grid; gap:.55rem; }
.footer-list a { color:#fff; font-size:.85rem; font-weight:600; letter-spacing:.3px; text-decoration:none; position:relative; }
.footer-list a:after { content:""; position:absolute; left:0; bottom:-3px; height:2px; width:0; background:var(--yellow); transition:width .35s var(--ease); }
.footer-list a:hover:after { width:100%; }
.contact-mini a { font-weight:600; word-break:break-word; }
.hours-list li { font-size:.75rem; letter-spacing:.4px; }
.hours-link { font-weight:700; font-size:.7rem; letter-spacing:.6px; }
.footer-note { margin:0 0 .85rem; font-size:.72rem; line-height:1.4; max-width:32ch; opacity:.85; }
.footer-form { display:flex; flex-direction:column; gap:.6rem; max-width:280px; }
.footer-form input { background:#fff; border:2px solid var(--pink-dark); border-radius:14px; padding:.65rem .75rem; font-size:.85rem; box-shadow:0 3px 10px -4px rgba(0,0,0,.25); }
.footer-form input:focus { border-color:var(--yellow-soft); }
.footer-submit { background:var(--yellow-soft); color:#222; font-size:.7rem; padding:.65rem 1rem; border-radius:50px; cursor:not-allowed; opacity:.7; }
.footer-status { font-size:.55rem; letter-spacing:.5px; min-height:1.1rem; opacity:.75; }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; gap:1rem; padding:2.4rem 0 2.6rem; margin-top:1rem; border-top:1px solid rgba(255,255,255,.18); position:relative; }
.legal { margin:0; font-size:.6rem; letter-spacing:.7px; text-transform:uppercase; font-weight:600; opacity:.85; display:flex; flex-wrap:wrap; gap:.4rem; align-items:center; }
.legal-link { color:#fff; text-decoration:none; position:relative; }
.legal-link:after { content:""; position:absolute; left:0; bottom:-3px; height:2px; background:var(--yellow); width:0; transition:width .35s var(--ease); }
.legal-link:hover:after { width:100%; }
.sep { opacity:.35; }
.to-top { position:static; width:46px; height:46px; display:flex; align-items:center; justify-content:center; background:var(--yellow); color:#222; border-radius:50%; font-weight:700; text-decoration:none; box-shadow:0 6px 20px -8px rgba(0,0,0,.3); border:3px solid #fff; transition:transform .4s var(--ease), box-shadow .4s var(--ease); }
.to-top .icon { width:1.1rem; height:1.1rem; }
.to-top:hover { transform:translateY(-6px); box-shadow:0 10px 28px -12px rgba(0,0,0,.35); }
.visually-hidden { position:absolute !important; width:1px !important; height:1px !important; padding:0 !important; margin:-1px !important; overflow:hidden !important; clip:rect(0 0 0 0) !important; white-space:nowrap !important; border:0 !important; }
@media (max-width:880px){
  .footer-bottom { flex-direction:column; align-items:flex-start; }
  .legal { font-size:.58rem; }
}
@media (max-width:620px){
  .footer-inner { grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); gap:1.9rem 1.1rem; }
  .footer-logo { width:64px; }
  .footer { padding:3.2rem 1rem 0; }
  .footer-bottom { padding:2rem 0 2.4rem; }
}
@media (prefers-reduced-motion:reduce){
  .social-btn:hover { transform:none; }
  .to-top:hover { transform:none; }
}
/* Icon fallback: if Font Awesome fails, ensure emoji sizing remains reasonable */
.fa-solid,.fa-brands { vertical-align:middle; }
.icon { display:inline-block; vertical-align:middle; fill:currentColor; }

/* Responsive Nav */
@media (max-width:880px){
  .nav-toggle { display:block; }
  .nav-list { position:absolute; top:100%; right:1rem; background:rgba(0,0,0,.6); backdrop-filter:blur(10px); padding:1.1rem 1.3rem; border-radius:18px; flex-direction:column; min-width:190px; transform:translateY(-10px); opacity:0; pointer-events:none; transition:opacity .45s var(--ease), transform .45s var(--ease); }
  .nav-list a { padding:.4rem 0; }
  .nav-list.open { opacity:1; transform:translateY(0); pointer-events:auto; }
}

/* Header nav no longer has active state */
