/* ===== SNACKCASA - styles.css ===== */
@import url('https://fonts.googleapis.com/css2?family=Fredoka:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,400&display=swap');

/* ---- Theme Variables ---- */
html.dark {
  --color-surface: #141414;
  --color-surface-card: rgba(255,255,255,0.04);
  --color-surface-elevated: #0D0D0D;
  --color-on-surface: #ffffff;
  --color-on-surface-70: rgba(255,255,255,0.7);
  --color-on-surface-60: rgba(255,255,255,0.6);
  --color-on-surface-50: rgba(255,255,255,0.5);
  --color-on-surface-40: rgba(255,255,255,0.4);
  --color-on-surface-30: rgba(255,255,255,0.3);
  --color-on-surface-10: rgba(255,255,255,0.1);
  --color-on-surface-05: rgba(255,255,255,0.05);
  --color-on-surface-hover: rgba(255,255,255,0.06);
  --color-type-bg: rgba(0,0,0,0.7);
}
html.light {
  --color-surface: #FBF8F4;
  --color-surface-card: #ffffff;
  --color-surface-elevated: #F2EDE6;
  --color-on-surface: #1a1a1a;
  --color-on-surface-70: rgba(26,26,26,0.7);
  --color-on-surface-60: rgba(26,26,26,0.6);
  --color-on-surface-50: rgba(26,26,26,0.5);
  --color-on-surface-40: rgba(26,26,26,0.4);
  --color-on-surface-30: rgba(26,26,26,0.3);
  --color-on-surface-10: rgba(26,26,26,0.1);
  --color-on-surface-05: rgba(26,26,26,0.05);
  --color-on-surface-hover: rgba(26,26,26,0.06);
  --color-type-bg: rgba(255,255,255,0.9);
}

/* ---- Base ---- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Fredoka',system-ui,-apple-system,sans-serif;
  -webkit-font-smoothing:antialiased;
  background:var(--color-surface);
  color:var(--color-on-surface);
  line-height:1.6;
  transition:background .3s,color .3s;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button{cursor:pointer;font-family:inherit;border:none;background:none;color:inherit}
ul{list-style:none}

/* ---- Brand Colors ---- */
:root{
  --brand-red:#E31837;
  --brand-yellow:#FFC72C;
  --brand-dark:#141414;
}

/* ---- Scrollbar hide ---- */
.scrollbar-hide::-webkit-scrollbar{display:none}
.scrollbar-hide{-ms-overflow-style:none;scrollbar-width:none}

/* ---- Animations ---- */
@keyframes fadeInUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes bounce{0%,100%{transform:translateY(-25%) translateX(-50%)}50%{transform:translateY(0) translateX(-50%)}}
.animate-fade-in-up{animation:fadeInUp .8s ease-out forwards}
.animate-fade-in{animation:fadeIn .4s ease-out forwards}
.animate-bounce{animation:bounce 2s infinite}

/* ---- Top Bar ---- */
.top-bar{
  background:var(--brand-red);color:#fff;font-size:12px;padding:6px 16px;
}
.top-bar-inner{max-width:1280px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}
.top-bar span{display:flex;align-items:center;gap:6px}

/* ---- Header ---- */
.header{
  position:sticky;top:0;z-index:50;
  background:var(--color-surface);transition:all .3s;
}
.header.scrolled{background:var(--color-surface);backdrop-filter:blur(20px);box-shadow:0 10px 40px rgba(0,0,0,.2)}
.header-inner{
  max-width:1280px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;
  padding:0 16px;height:64px;
}
@media(min-width:768px){.header-inner{height:80px;padding:0 24px}}
.header-logo{height:48px;width:auto;object-fit:contain}
@media(min-width:768px){.header-logo{height:64px}}
.nav-links{display:none;align-items:center;gap:4px}
@media(min-width:768px){.nav-links{display:flex}}
.nav-link{
  padding:8px 16px;font-size:14px;font-weight:600;color:var(--color-on-surface-70);
  letter-spacing:.05em;text-transform:uppercase;transition:color .2s;
}
.nav-link:hover{color:var(--brand-yellow)}
.header-right{display:flex;align-items:center;gap:8px}
@media(min-width:640px){.header-right{gap:12px}}
.theme-toggle{
  width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  color:var(--color-on-surface-60);transition:all .3s;position:relative;
}
.theme-toggle:hover{color:var(--brand-yellow);background:var(--color-on-surface-05)}
.theme-toggle svg{position: flex ;transition:all .3s}
.theme-toggle .sun-icon{opacity:1;transform:rotate(0) scale(1)}
.theme-toggle .moon-icon{opacity:0;transform:rotate(-90deg) scale(0)}
html.light .theme-toggle .sun-icon{opacity:0;transform:rotate(90deg) scale(0)}
html.light .theme-toggle .moon-icon{opacity:1;transform:rotate(0) scale(1)}
.view-menu-btn{
  display:none;padding:10px 20px;background:var(--brand-red);color:#fff;
  font-size:14px;font-weight:700;border-radius:8px;letter-spacing:.05em;transition:background .2s;
}
.view-menu-btn:hover{background:#c41430}
@media(min-width:768px){.view-menu-btn{display:inline-flex}}
.mobile-toggle{display:block;padding:8px;color:var(--color-on-surface)}
@media(min-width:768px){.mobile-toggle{display:none}}

/* Mobile Nav */
.mobile-nav{
  overflow:hidden;max-height:0;transition:max-height .3s;
  background:var(--color-surface);backdrop-filter:blur(20px);
}
.mobile-nav.open{max-height:400px;border-top:1px solid var(--color-on-surface-10)}
.mobile-nav nav{display:flex;flex-direction:column;padding:16px 24px}
.mobile-nav-link{
  padding:12px 0;text-align:left;color:var(--color-on-surface-70);font-weight:500;
  letter-spacing:.05em;border-bottom:1px solid var(--color-on-surface-05);transition:color .2s;
}
.mobile-nav-link:last-of-type{border:none}
.mobile-nav-link:hover{color:var(--brand-yellow)}
.mobile-cta{
  margin-top:12px;padding:12px;background:var(--brand-red);color:#fff;
  font-weight:700;border-radius:8px;text-align:center;
}

/* ---- Hero ---- */
.hero{
  position:relative;height:100svh;min-height:600px;overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;transition:opacity 1s;
}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to bottom,rgba(0,0,0,.7),rgba(0,0,0,.5),var(--color-surface));
}
.hero-content{
  position:relative;z-index:10;height:100%;display:flex;flex-direction:column;
  align-items:center;justify-content:center;padding:0 16px;text-align:center;
}
.hero-logo{height:112px;margin:0 auto 24px;filter:drop-shadow(0 10px 30px rgba(0,0,0,.5))}
@media(min-width:640px){.hero-logo{height:144px}}
@media(min-width:768px){.hero-logo{height:176px}}
.hero-title{font-size:2.25rem;font-weight:900;color:#fff;line-height:1.1;letter-spacing:-.02em}
@media(min-width:640px){.hero-title{font-size:3rem}}
@media(min-width:768px){.hero-title{font-size:4.5rem}}
.hero-title .yellow{color:var(--brand-yellow)}
.hero-desc{margin-top:16px;font-size:1rem;color:rgba(255,255,255,.7);max-width:640px;line-height:1.7}
@media(min-width:768px){.hero-desc{margin-top:24px;font-size:1.25rem}}
.hero-buttons{margin-top:32px;display:flex;flex-direction:column;gap:16px;justify-content:center}
@media(min-width:640px){.hero-buttons{flex-direction:row}}
.btn-primary{
  padding:16px 32px;background:var(--brand-red);color:#fff;font-weight:700;font-size:1.125rem;
  border-radius:12px;transition:all .2s;box-shadow:0 10px 30px rgba(227,24,55,.3);
}
.btn-primary:hover{background:#c41430;transform:scale(1.05)}
.btn-secondary{
  padding:16px 32px;border:2px solid rgba(255,255,255,.3);color:#fff;font-weight:700;
  font-size:1.125rem;border-radius:12px;transition:all .2s;backdrop-filter:blur(4px);
}
.btn-secondary:hover{background:rgba(255,255,255,.1)}
.hero-scroll{
  position:absolute;bottom:32px;left:50%;z-index:10;color:rgba(255,255,255,.5);transition:color .2s;
}
.hero-scroll:hover{color:#fff}
.hero-dots{
  position:absolute;bottom:32px;right:24px;z-index:10;display:flex;gap:8px;
}
.hero-dot{
  width:8px;height:8px;border-radius:9999px;transition:all .3s;
}
.hero-dot.active{width:24px;background:var(--brand-yellow)}
.hero-dot:not(.active){background:rgba(255,255,255,.4)}

/* ---- Section Shared ---- */
.section{padding:64px 0}
@media(min-width:768px){.section{padding:96px 0}}
.section-inner{max-width:1280px;margin:0 auto;padding:0 16px}
@media(min-width:640px){.section-inner{padding:0 24px}}
.section-header{text-align:center;margin-bottom:48px}
.section-badge{
  display:inline-flex;align-items:center;gap:8px;padding:6px 16px;
  font-size:14px;font-weight:600;border-radius:9999px;margin-bottom:16px;
}
.section-title{font-size:1.875rem;font-weight:900;color:var(--color-on-surface)}
@media(min-width:768px){.section-title{font-size:3rem}}
.section-title .red{color:var(--brand-red)}
.section-title .yellow{color:var(--brand-yellow)}
.section-subtitle{margin-top:12px;font-size:1.125rem;color:var(--color-on-surface-50);max-width:560px;margin-left:auto;margin-right:auto}
.bg-surface{background:var(--color-surface)}
.bg-elevated{background:var(--color-surface-elevated)}

/* ---- Featured ---- */
.featured-grid{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:640px){.featured-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.featured-grid{grid-template-columns:repeat(3,1fr)}}
.featured-card{
  position:relative;background:var(--color-surface-card);border-radius:16px;overflow:hidden;
  transition:all .3s;
}
.featured-card:hover{box-shadow:0 0 0 2px rgba(255,199,44,.3)}
.featured-card-img{position:relative;height:192px;overflow:hidden;background:var(--color-surface-elevated)}
@media(min-width:640px){.featured-card-img{height:208px}}
.featured-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.featured-card:hover .featured-card-img img{transform:scale(1.1)}
.featured-card-img .gradient{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.4),transparent)}
.card-badge{
  position:absolute;top:12px;left:12px;padding:4px 12px;font-size:12px;font-weight:700;
  border-radius:9999px;display:flex;align-items:center;gap:4px;
}
.card-badge.bestseller{background:var(--brand-yellow);color:var(--brand-dark)}
.card-badge.popular{background:var(--brand-red);color:#fff}
.featured-card-body{padding:20px}
.type-badge{
  display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;
  border:2px solid;border-radius:2px;
}
.type-badge.veg{border-color:#10b981}
.type-badge.nonveg{border-color:#dc2626}
.type-badge.egg{border-color:#f59e0b}
.type-badge .dot{width:6px;height:6px;border-radius:50%}
.type-badge.veg .dot{background:#10b981}
.type-badge.nonveg .dot{background:#dc2626}
.type-badge.egg .dot{background:#f59e0b}
.card-category{font-size:12px;color:var(--color-on-surface-40);text-transform:uppercase;letter-spacing:.1em}
.card-name{font-size:1.125rem;font-weight:700;color:var(--color-on-surface);transition:color .3s}
.featured-card:hover .card-name{color:var(--brand-yellow)}

/* ---- Menu ---- */
.filter-row{display:flex;justify-content:center;gap:8px;margin-bottom:24px;flex-wrap:wrap}
.filter-btn{
  padding:8px 16px;font-size:14px;font-weight:600;border-radius:9999px;transition:all .2s;
  background:var(--color-on-surface-05);color:var(--color-on-surface-60);
}
.filter-btn:hover{background:var(--color-on-surface-10);color:var(--color-on-surface)}
.filter-btn.active{background:var(--brand-red);color:#fff;box-shadow:0 4px 20px rgba(227,24,55,.2)}
.filter-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px}
.filter-dot.veg{background:#10b981}.filter-dot.nonveg{background:#ef4444}.filter-dot.egg{background:#f59e0b}

.tabs-wrapper{position:relative;margin-bottom:32px}

.tabs-scroll{display:flex;gap:8px;overflow-x:auto;padding:4px 8px;scroll-snap-type:x mandatory}
.tab-btn{
  display:flex;align-items:center;gap:8px;padding:10px 16px;border-radius:12px;
  font-size:14px;font-weight:600;white-space:nowrap;transition:all .2s;scroll-snap-align:start;flex-shrink:0;
  background:var(--color-on-surface-05);color:var(--color-on-surface-60);
}
.tab-btn:hover{background:var(--color-on-surface-10);color:var(--color-on-surface)}
.tab-btn.active{background:var(--brand-red);color:#fff;box-shadow:0 4px 20px rgba(227,24,55,.2)}
.tab-btn svg{width:16px;height:16px}

.menu-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
@media(min-width:640px){.menu-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1024px){.menu-grid{grid-template-columns:repeat(4,1fr)}}
@media(min-width:1280px){.menu-grid{grid-template-columns:repeat(5,1fr)}}
.menu-card{
  background:var(--color-surface-card);border-radius:12px;overflow:hidden;
  transition:all .3s;
}
.menu-card:hover{box-shadow:0 0 0 2px rgba(255,199,44,.3)}
.menu-card-img{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--color-surface-elevated)}
.menu-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.menu-card:hover .menu-card-img img{transform:scale(1.1)}
.menu-card-img .gradient{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.3),transparent)}
.menu-card-img .item-badge{
  position:absolute;top:8px;left:8px;padding:2px 8px;font-size:10px;font-weight:700;
  border-radius:9999px;display:flex;align-items:center;gap:4px;
}
.item-badge.bestseller{background:var(--brand-yellow);color:var(--brand-dark)}
.item-badge.popular{background:var(--brand-red);color:#fff}
.menu-card-img .type-indicator{
  position:absolute;bottom:8px;right:8px;width:20px;height:20px;border-radius:4px;
  background:var(--color-type-bg);backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;
}
.type-indicator .dot{width:8px;height:8px;border-radius:50%}
.type-indicator .dot.veg{background:#10b981}
.type-indicator .dot.nonveg{background:#dc2626}
.type-indicator .dot.egg{background:#f59e0b}
.menu-card-body{padding:12px}
.menu-card-name{font-size:14px;font-weight:600;color:var(--color-on-surface);transition:color .3s;line-height:1.3}
.menu-card:hover .menu-card-name{color:var(--brand-yellow)}

.empty-state{text-align:center;padding:48px 0;color:var(--color-on-surface-40);font-size:1.125rem}

.info-grid{display:grid;grid-template-columns:1fr;gap:24px;margin-top:48px}
@media(min-width:768px){.info-grid{grid-template-columns:1fr 1fr}}
.info-card{background:var(--color-surface-card);border-radius:12px;padding:24px}
.info-title{font-size:1.125rem;font-weight:700;color:var(--brand-yellow);margin-bottom:16px;display:flex;align-items:center;gap:8px}
.info-title .bar{width:4px;height:24px;background:var(--brand-yellow);border-radius:9999px}
.info-item{display:flex;align-items:center;color:var(--color-on-surface-70);font-size:14px;padding:6px 0}
.info-item .dot-marker{width:6px;height:6px;border-radius:50%;margin-right:12px;flex-shrink:0}
.legend{margin-top:20px;padding-top:16px;border-top:1px solid var(--color-on-surface-10);display:flex;flex-wrap:wrap;gap:16px}
.legend-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--color-on-surface-50)}
.legend-box{width:12px;height:12px;border:1px solid;border-radius:2px;display:flex;align-items:center;justify-content:center}
.legend-box .dot{width:6px;height:6px;border-radius:50%}

/* ---- About ---- */
.about-grid{display:grid;grid-template-columns:1fr;gap:48px;align-items:center}
@media(min-width:1024px){.about-grid{grid-template-columns:1fr 1fr}}
.about-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 16px;background:rgba(227,24,55,.1);color:var(--brand-red);font-size:14px;font-weight:600;border-radius:9999px;margin-bottom:24px}
.about-title{font-size:1.875rem;font-weight:900;color:var(--color-on-surface);line-height:1.15}
@media(min-width:768px){.about-title{font-size:3rem}}
.about-text{margin-top:24px;color:var(--color-on-surface-60);font-size:1rem;line-height:1.7}
.about-text p{margin-bottom:16px}
.about-text .quote{color:rgba(255,199,44,.8);font-weight:500;font-style:italic}
.about-tags{margin-top:32px;display:flex;flex-wrap:wrap;gap:16px}
.about-tag{
  display:inline-flex;align-items:center;gap:8px;padding:8px 16px;
  background:var(--color-on-surface-05);border-radius:8px;font-size:14px;color:var(--color-on-surface-70);
}
.about-tag svg{color:var(--brand-yellow)}
.about-images{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.about-img{border-radius:16px;overflow:hidden;aspect-ratio:1}
.about-img:nth-child(2){margin-top:32px}
.about-img img{width:100%;height:100%;object-fit:cover}
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:24px}
@media(min-width:640px){.stats-grid{grid-template-columns:repeat(4,1fr)}}
.stat-card{
  background:var(--color-surface-card);border-radius:12px;padding:16px;text-align:center;
  transition:background .2s;
}
.stat-card:hover{background:var(--color-on-surface-hover)}
.stat-card svg{margin:0 auto 8px;color:var(--brand-red);transition:color .2s}
.stat-card:hover svg{color:var(--brand-yellow)}
.stat-value{font-size:1.5rem;font-weight:900;color:var(--color-on-surface)}
.stat-label{font-size:11px;color:var(--color-on-surface-40);margin-top:4px;text-transform:uppercase;letter-spacing:.1em}

/* ---- Contact ---- */
.contact-grid{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:768px){.contact-grid{grid-template-columns:repeat(3,1fr)}}
.contact-card{
  background:var(--color-surface-card);border-radius:16px;padding:24px;transition:all .3s;
}
@media(min-width:768px){.contact-card{padding:32px}}
.contact-card:hover{box-shadow:0 0 0 1px var(--color-on-surface-10)}
.contact-icon{
  width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  margin-bottom:16px;transition:background .2s;
}
.contact-card-title{font-size:1.25rem;font-weight:700;color:var(--color-on-surface);margin-bottom:8px}
.contact-card p,.contact-card a{color:var(--color-on-surface-50);font-size:14px;transition:color .2s}
.contact-card a:hover{color:var(--brand-yellow)}
.contact-link{display:flex;align-items:center;gap:8px;padding:4px 0}
.contact-hours{display:flex;justify-content:space-between;font-size:14px;padding:4px 0}
.contact-hours .label{color:var(--color-on-surface-50)}
.contact-hours .value{color:var(--color-on-surface);font-weight:500}

.cta-banner{
  margin-top:48px;background:linear-gradient(to right,var(--brand-red),#c41430);border-radius:16px;
  padding:32px;text-align:center;position:relative;overflow:hidden;
}
@media(min-width:768px){.cta-banner{padding:48px}}
.cta-banner .pattern{position:absolute;inset:0;opacity:.5;background-image:url("data:image/svg+xml,%3Csvg width='30' height='30' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 10h30M10 0v30' stroke='white' stroke-opacity='0.05' fill='none'/%3E%3C/svg%3E")}
.cta-banner .inner{position:relative;z-index:10}
.cta-title{font-size:1.5rem;font-weight:900;color:#fff;margin-bottom:12px}
@media(min-width:768px){.cta-title{font-size:2.25rem}}
.cta-desc{color:rgba(255,255,255,.8);font-size:1.125rem;margin-bottom:24px;max-width:560px;margin-left:auto;margin-right:auto}
.cta-buttons{display:flex;flex-direction:column;gap:16px;justify-content:center}
@media(min-width:640px){.cta-buttons{flex-direction:row}}
.btn-cta-primary{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:16px 32px;background:#fff;color:var(--brand-red);font-weight:700;font-size:1.125rem;
  border-radius:12px;transition:all .2s;
}
.btn-cta-primary:hover{background:var(--brand-yellow);color:var(--brand-dark)}
.btn-cta-secondary{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:16px 32px;border:2px solid rgba(255,255,255,.3);color:#fff;font-weight:700;
  font-size:1.125rem;border-radius:12px;transition:all .2s;
}
.btn-cta-secondary:hover{background:rgba(255,255,255,.1)}

/* ---- Footer ---- */
.footer{background:var(--color-surface);border-top:1px solid var(--color-on-surface-05)}
.footer-inner{max-width:1280px;margin:0 auto;padding:0 16px}
@media(min-width:640px){.footer-inner{padding:0 24px}}
.footer-grid{
  padding:48px 0;display:grid;grid-template-columns:1fr;gap:40px;
}
@media(min-width:640px){.footer-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.footer-grid{grid-template-columns:1fr 1fr 1fr 1fr;padding:64px 0}}
.footer-brand-logo{height:64px;margin-bottom:16px}
.footer-brand-desc{color:var(--color-on-surface-40);font-size:14px;line-height:1.7;margin-bottom:16px}
.social-links{display:flex;gap:12px}
.social-link{
  width:36px;height:36px;border-radius:8px;background:var(--color-on-surface-05);
  display:flex;align-items:center;justify-content:center;color:var(--color-on-surface-40);transition:all .2s;
}
.social-link:hover{background:var(--brand-red);color:#fff}
.social-link svg{width:16px;height:16px}
.footer-heading{color:var(--color-on-surface);font-weight:700;font-size:14px;text-transform:uppercase;letter-spacing:.1em;margin-bottom:16px}
.footer-link-list{display:flex;flex-direction:column;gap:10px}
.footer-link{color:var(--color-on-surface-40);font-size:14px;transition:color .2s;text-align:left}
.footer-link:hover{color:var(--brand-yellow)}
.footer-contact-item{display:flex;align-items:flex-start;gap:8px;font-size:14px;color:var(--color-on-surface-40);padding:4px 0}
.footer-contact-item svg{flex-shrink:0;margin-top:2px;color:var(--brand-red)}
.footer-contact-item a{color:var(--color-on-surface-40);transition:color .2s}
.footer-contact-item a:hover{color:var(--brand-yellow)}
.footer-bottom{
  border-top:1px solid var(--color-on-surface-05);padding:24px 0;
  display:flex;flex-direction:column;align-items:center;gap:16px;
}
@media(min-width:640px){.footer-bottom{flex-direction:row;justify-content:space-between}}
.footer-copy{color:var(--color-on-surface-30);font-size:14px}
.back-to-top{
  width:40px;height:40px;border-radius:50%;background:var(--color-on-surface-05);
  display:flex;align-items:center;justify-content:center;color:var(--color-on-surface-40);transition:all .2s;
}
.back-to-top:hover{background:var(--brand-red);color:#fff}

/* ---- Responsive Top Bar ---- */
@media(max-width:767px){.top-bar{display:none}}

/* ---- Decorative Blurs ---- */
.deco-blob{position:absolute;border-radius:50%;filter:blur(60px);pointer-events:none}
