/* ====== RESET & BASE ====== */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Plus Jakarta Sans',sans-serif;
  background:#FFF8F0;
  color:#2D1B14;
  line-height:1.6;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ====== DESIGN TOKENS ====== */
:root{
  --cream:#FFF8F0;
  --coral:#ee5b2b;
  --coral-grad:linear-gradient(145deg,#ee5b2b,#ffb088);
  --peach:#ffb088;
  --golden:#fbc02d;
  --green:#6BC5A0;
  --brown:#2D1B14;
  --text:rgba(45,27,20,1);
  --text-sec:rgba(45,27,20,0.65);
  --text-muted:rgba(45,27,20,0.4);
  --glass:rgba(255,255,255,0.45);
  --glass-border:rgba(255,255,255,0.35);
  --glass-strong:rgba(255,255,255,0.6);
  --shadow:0 2px 20px rgba(45,27,20,0.06);
  --shadow-lg:0 8px 40px rgba(45,27,20,0.08);
  --radius:20px;
  --radius-lg:28px;
  --max-w:1200px;
}

/* ====== AMBIENT BACKGROUND BLOBS ====== */
.ambient-blob{
  position:fixed;
  border-radius:50%;
  pointer-events:none;
  z-index:0;
}
.ab-1{width:500px;height:500px;background:var(--coral);opacity:0.04;top:-150px;right:-100px;animation:drift1 18s ease-in-out infinite;translate:var(--sx,0px) var(--sy,0px)}
.ab-2{width:400px;height:400px;background:var(--green);opacity:0.05;bottom:-100px;left:-100px;animation:drift2 22s ease-in-out infinite;translate:var(--sx,0px) var(--sy,0px)}
.ab-3{width:300px;height:300px;background:var(--golden);opacity:0.04;top:40%;left:-80px;animation:drift1 15s ease-in-out infinite 3s;translate:var(--sx,0px) var(--sy,0px)}
.ab-4{width:350px;height:350px;background:var(--peach);opacity:0.04;top:60%;right:-120px;animation:drift2 20s ease-in-out infinite 5s;translate:var(--sx,0px) var(--sy,0px)}
@keyframes drift1{0%,100%{transform:translate(0,0)}50%{transform:translate(25px,20px)}}
@keyframes drift2{0%,100%{transform:translate(0,0)}50%{transform:translate(-20px,-25px)}}

/* ====== TYPOGRAPHY ====== */
.heading{font-family:'Playfair Display',serif;font-weight:700;color:var(--brown);line-height:1.15;letter-spacing:-0.5px}
.section-heading{font-size:clamp(28px,4vw,42px);text-align:center;margin-bottom:16px}
.section-sub{text-align:center;color:var(--text-sec);font-size:18px;max-width:600px;margin:0 auto 48px}

/* ====== LAYOUT ====== */
.container{max-width:var(--max-w);margin:0 auto;padding:0 24px;position:relative;z-index:1}
section{padding:80px 0}
.section-alt{background:rgba(255,255,255,0.3)}
@media(max-width:768px){section{padding:56px 0}}

/* ====== GLASS CARD ====== */
.glass{
  background:var(--glass);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid var(--glass-border);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  transition:transform 0.3s ease,box-shadow 0.3s ease;
}
.glass:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}

/* ====== BUTTONS ====== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:'Plus Jakarta Sans',sans-serif;
  font-weight:700;font-size:16px;
  border:none;border-radius:999px;
  padding:14px 32px;cursor:pointer;
  transition:all 0.25s ease;
  text-decoration:none;
}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:scale(0.97)}
.btn-coral{background:var(--coral-grad);color:#fff;box-shadow:0 4px 20px rgba(238,91,43,0.3)}
.btn-coral:hover{box-shadow:0 8px 30px rgba(238,91,43,0.4)}
.btn-white{background:#fff;color:var(--brown);box-shadow:0 2px 12px rgba(0,0,0,0.08)}
.btn-outline{background:transparent;color:var(--coral);border:2px solid var(--coral)}
.btn-sm{padding:10px 24px;font-size:14px}

/* ====== FORM INPUT ====== */
.form-input{
  border-radius:999px;
  border:1px solid rgba(45,27,20,0.1);
  background:rgba(255,255,255,0.6);
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:15px;color:var(--brown);
  outline:none;transition:border-color 0.2s;
}
.form-input:focus{border-color:var(--coral)}
.form-input::placeholder{color:var(--text-muted)}

/* ====== FORM VALIDATION ====== */
.form-tooltip{
  position:absolute;
  bottom:calc(100% + 10px);
  left:20px;
  background:var(--brown);
  color:#FFF8F0;
  font-size:13px;
  font-weight:600;
  padding:10px 16px;
  border-radius:12px;
  box-shadow:0 4px 20px rgba(45,27,20,0.15);
  white-space:nowrap;
  opacity:0;
  transform:translateY(4px);
  transition:opacity 0.2s ease,transform 0.2s ease;
  pointer-events:none;
  z-index:10;
}
.form-tooltip.visible{
  opacity:1;
  transform:translateY(0);
}
.form-tooltip::after{
  content:'';
  position:absolute;
  top:100%;
  left:24px;
  border:6px solid transparent;
  border-top-color:var(--brown);
}
.form-input-error{
  border-color:var(--coral) !important;
  box-shadow:0 0 0 3px rgba(238,91,43,0.12) !important;
}

/* ====== NAVBAR ====== */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:16px 0;
  transition:all 0.3s ease;
}
.navbar.scrolled{
  background:rgba(255,248,240,0.8);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(45,27,20,0.06);
  padding:12px 0;
}
.navbar .container{display:flex;align-items:center;justify-content:space-between}
.nav-logo{
  font-family:'Playfair Display',serif;
  font-size:24px;font-weight:800;
  color:var(--brown);
  display:flex;align-items:center;gap:8px;
}
.nav-logo .nav-icon{margin-right:0}
.nav-links{display:flex;align-items:center;gap:32px}
.nav-links a{font-weight:600;font-size:15px;color:var(--text-sec);transition:color 0.2s}
.nav-links a:hover{color:var(--coral)}
.nav-cta{margin-left:8px}
.nav-hamburger{display:none;background:none;border:none;cursor:pointer;color:var(--brown);padding:4px}
@media(max-width:768px){
  .nav-links{display:none}
  .nav-links.open{
    display:flex;flex-direction:column;
    position:absolute;top:100%;left:0;right:0;
    background:rgba(255,248,240,0.95);
    backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
    padding:24px;gap:20px;
    border-bottom:1px solid rgba(45,27,20,0.06);
  }
  .nav-hamburger{display:block}
}

/* ====== NAVBAR ANIMATED ICON ====== */
.nav-icon{
  position:relative;width:60px;height:60px;flex-shrink:0;
}
.nav-icon .icon-bg{
  position:absolute;inset:0;border-radius:22.5%;
  background:var(--cream);
  box-shadow:0 4px 16px rgba(238,91,43,0.18),0 2px 6px rgba(0,0,0,0.06);
  overflow:hidden;
}
.nav-icon .icon-blob{
  position:absolute;top:50%;left:50%;width:62%;height:62%;
  background:rgba(255,176,136,0.4);
  border-radius:40% 60% 70% 30%/50% 60% 40% 50%;
  transform-origin:center;
  animation:blobRot 8s ease-in-out infinite;
}
@keyframes blobRot{0%{transform:translate(-50%,-50%) rotate(0deg) scale(1)}50%{transform:translate(-50%,-50%) rotate(180deg) scale(1.03)}100%{transform:translate(-50%,-50%) rotate(360deg) scale(1)}}
.nav-icon .icon-blob-inner{
  position:absolute;top:50%;left:50%;width:48%;height:48%;
  background:rgba(255,176,136,0.2);
  border-radius:60% 40% 30% 70%/60% 30% 70% 40%;
  transform-origin:center;
  animation:blobRot 6s ease-in-out infinite reverse;
}
.nav-icon .utensils-wrap{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:10;
  width:18px;height:18px;
}
.nav-icon .utensil-fork,.nav-icon .utensil-knife{
  position:absolute;top:0;left:0;width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
  transform-origin:50% 15%;
}
.nav-icon .utensil-fork{clip-path:inset(0 50% 0 0);animation:swayFork 3s ease-in-out infinite}
.nav-icon .utensil-knife{clip-path:inset(0 0 0 50%);animation:swayKnife 3s ease-in-out infinite}
@keyframes swayFork{0%,100%{transform:rotate(8deg)}50%{transform:rotate(0deg)}}
@keyframes swayKnife{0%,100%{transform:rotate(-8deg)}50%{transform:rotate(0deg)}}
.nav-icon .utensil-fork .material-symbols-outlined,
.nav-icon .utensil-knife .material-symbols-outlined{
  font-size:18px;color:var(--coral);font-variation-settings:'FILL' 1,'wght' 400;
}
.nav-icon .icon-food-dot{position:absolute;border-radius:50%;z-index:5}
.nav-icon .ifd-1{width:4px;height:4px;background:var(--coral);opacity:0.5;top:12%;left:14%;animation:foodBob 3.5s ease-in-out infinite}
.nav-icon .ifd-2{width:3px;height:3px;background:var(--green);opacity:0.5;top:15%;right:16%;animation:foodBob 4s ease-in-out infinite 0.3s}
.nav-icon .ifd-3{width:4px;height:4px;background:var(--golden);opacity:0.5;bottom:15%;left:13%;animation:foodBob 3.8s ease-in-out infinite 0.6s}
.nav-icon .ifd-4{width:3px;height:3px;background:var(--coral);opacity:0.4;bottom:13%;right:15%;animation:foodBob 4.2s ease-in-out infinite 0.9s}
@keyframes foodBob{0%,100%{transform:translate(0,0)}33%{transform:translate(2px,-2px)}66%{transform:translate(-2px,2px)}}

/* ====== FOOTER ====== */
.footer{background:var(--brown);color:rgba(255,248,240,0.7);padding:64px 0 32px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:48px}
.footer-brand{font-family:'Playfair Display',serif;font-size:24px;font-weight:800;color:#FFF8F0;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.footer-brand .material-symbols-outlined{color:var(--coral);font-variation-settings:'FILL' 1}
.footer-desc{font-size:14px;line-height:1.7;max-width:280px;margin-bottom:20px}
.footer-social{display:flex;gap:12px}
.footer-social a{
  width:40px;height:40px;border-radius:50%;
  background:rgba(255,248,240,0.08);
  display:flex;align-items:center;justify-content:center;
  transition:background 0.2s;font-size:18px;color:rgba(255,248,240,0.6);
}
.footer-social a:hover{background:rgba(255,248,240,0.15);color:#FFF8F0}
.footer h4{font-size:14px;font-weight:700;color:#FFF8F0;margin-bottom:16px;text-transform:uppercase;letter-spacing:0.5px}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer ul li a{font-size:14px;transition:color 0.2s}
.footer ul li a:hover{color:#FFF8F0}
.footer-bottom{
  border-top:1px solid rgba(255,248,240,0.08);
  padding-top:24px;
  display:flex;justify-content:space-between;align-items:center;
  font-size:13px;flex-wrap:wrap;gap:12px;
}
@media(max-width:768px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .footer-bottom{flex-direction:column;text-align:center}
}
@media(max-width:500px){.footer-grid{grid-template-columns:1fr}}

/* ====== ANIMATIONS ====== */
.fade-up{opacity:0;transform:translateY(30px);transition:opacity 0.8s ease,transform 0.8s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}

.hero-entrance{opacity:0;transform:translateY(40px) scale(0.97);transition:opacity 0.9s cubic-bezier(0.16,1,0.3,1),transform 0.9s cubic-bezier(0.16,1,0.3,1)}
.hero-entrance.visible{opacity:1;transform:translateY(0) scale(1)}
.hero-entrance.d1{transition-delay:0.1s}
.hero-entrance.d2{transition-delay:0.3s}
.hero-entrance.d3{transition-delay:0.5s}
.hero-entrance.d4{transition-delay:0.7s}
.hero-entrance.d5{transition-delay:0.9s}

/* ====== MODAL OVERLAY ====== */
.modal-overlay{
  position:fixed;inset:0;z-index:1000;
  background:rgba(45,27,20,0.5);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  display:none;align-items:center;justify-content:center;
  padding:24px;
  opacity:0;transition:opacity 0.3s ease;
}
.modal-overlay.active{display:flex;opacity:1}
.modal-content{
  background:var(--cream);
  border-radius:var(--radius-lg);
  padding:48px 40px;
  max-width:480px;width:100%;
  text-align:center;
  position:relative;
  box-shadow:0 24px 80px rgba(45,27,20,0.18);
  transform:translateY(20px);
  transition:transform 0.3s ease;
}
.modal-overlay.active .modal-content{transform:translateY(0)}
.modal-close{
  position:absolute;top:16px;right:16px;
  background:none;border:none;cursor:pointer;
  color:var(--text-muted);font-size:28px;
  width:40px;height:40px;
  display:flex;align-items:center;justify-content:center;
  border-radius:50%;
  transition:background 0.2s,color 0.2s;
}
.modal-close:hover{background:rgba(45,27,20,0.06);color:var(--brown)}
.modal-content h3{
  font-family:'Playfair Display',serif;
  font-size:24px;font-weight:700;
  color:var(--brown);margin-bottom:12px;
}
.modal-content p{
  color:var(--text-sec);font-size:15px;
  line-height:1.6;margin-bottom:24px;
}
.modal-content .modal-form{
  display:flex;gap:12px;max-width:360px;margin:0 auto;
}
.modal-content .modal-form input{flex:1;min-width:0;padding:12px 18px}
@media(max-width:500px){
  .modal-content{padding:36px 24px}
  .modal-content .modal-form{flex-direction:column}
  .modal-content .modal-form .btn{width:100%}
}

/* ====== FINAL CTA ====== */
.cta-section{
  background:var(--coral-grad);
  padding:80px 0;
  text-align:center;
  position:relative;overflow:hidden;
}
.cta-section::before{
  content:'';position:absolute;top:-100px;right:-100px;
  width:400px;height:400px;border-radius:50%;
  background:rgba(255,255,255,0.08);pointer-events:none;
}
.cta-section h2{
  font-family:'Playfair Display',serif;font-size:clamp(28px,4vw,40px);
  font-weight:700;color:#fff;margin-bottom:12px;
}
.cta-section p{color:rgba(255,255,255,0.85);font-size:18px;margin-bottom:32px}
.cta-form{display:flex;gap:12px;max-width:460px;margin:0 auto 16px;justify-content:center}
.cta-form input{
  flex:1;min-width:0;padding:14px 20px;border-radius:999px;border:none;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:16px;
  background:rgba(255,255,255,0.95);color:var(--brown);outline:none;
}
.cta-form input::placeholder{color:var(--text-muted)}
.cta-trust{font-size:13px;color:rgba(255,255,255,0.7)}

/* ====== PAGE HERO (shared by legal, support, blog) ====== */
.page-hero{padding:140px 0 48px;text-align:center}
.page-hero h1{font-size:clamp(32px,4.5vw,48px);margin-bottom:12px}
.page-hero p{color:var(--text-sec);font-size:16px}
.page-hero--spaced p{margin-bottom:32px}

.breadcrumb{font-size:13px;color:var(--text-muted);margin-bottom:-8px}
.breadcrumb a{color:var(--text-sec);text-decoration:underline;text-underline-offset:2px}
.breadcrumb a:hover{color:var(--coral)}

.legal-content{
  padding:0 0 80px;
}
.legal-content .container{
  display:grid;
  grid-template-columns:220px 1fr;
  gap:48px;
  align-items:start;
}
.legal-toc{
  position:sticky;top:100px;
  background:var(--glass);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid var(--glass-border);
  border-radius:var(--radius);
  padding:24px;
}
.legal-toc h4{
  font-size:13px;font-weight:700;color:var(--brown);
  text-transform:uppercase;letter-spacing:0.5px;
  margin-bottom:16px;
}
.legal-toc ol{
  list-style:none;counter-reset:toc;
  display:flex;flex-direction:column;gap:8px;
}
.legal-toc ol li{counter-increment:toc}
.legal-toc ol li a{
  font-size:13px;color:var(--text-sec);
  display:flex;gap:8px;
  transition:color 0.2s;
}
.legal-toc ol li a::before{
  content:counter(toc) ".";
  color:var(--text-muted);font-weight:600;
  min-width:18px;
}
.legal-toc ol li a:hover{color:var(--coral)}

.legal-body{max-width:740px}
.legal-body h2{
  font-family:'Playfair Display',serif;
  font-size:22px;font-weight:700;
  color:var(--brown);
  margin:48px 0 16px;
  padding-top:16px;
}
.legal-body h2:first-child{margin-top:0}
.legal-body h3{
  font-size:17px;font-weight:700;
  color:var(--brown);
  margin:28px 0 10px;
}
.legal-body p{
  color:var(--text-sec);font-size:15px;
  line-height:1.8;margin-bottom:16px;
}
.legal-body ul,.legal-body ol{
  color:var(--text-sec);font-size:15px;
  line-height:1.8;margin-bottom:16px;
  padding-left:24px;
}
.legal-body li{margin-bottom:6px}
.legal-body table{
  width:100%;border-collapse:collapse;
  margin-bottom:24px;font-size:14px;
}
.legal-body table th{
  text-align:left;padding:12px 16px;
  background:rgba(45,27,20,0.04);
  border-bottom:2px solid rgba(45,27,20,0.08);
  font-weight:700;color:var(--brown);
}
.legal-body table td{
  padding:12px 16px;
  border-bottom:1px solid rgba(45,27,20,0.06);
  color:var(--text-sec);
}
.legal-body a{color:var(--coral);text-decoration:underline;text-underline-offset:2px}
.legal-body a:hover{color:var(--brown)}
.legal-body strong{color:var(--brown)}

@media(max-width:768px){
  .legal-content .container{
    grid-template-columns:1fr;
    gap:24px;
  }
  .legal-toc{
    position:static;
  }
}

/* ====== SUPPORT PAGE ====== */
.support-search{
  max-width:500px;margin:0 auto;position:relative;
}
.support-search input{width:100%;padding:16px 20px 16px 48px;font-size:16px}
.support-search .search-icon{
  position:absolute;left:18px;top:50%;transform:translateY(-50%);
  color:var(--text-muted);font-size:22px;
  font-variation-settings:'FILL' 0;
}

.support-cards{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
  margin-bottom:64px;
}
.support-card{padding:28px;text-align:center}
.support-card .support-emoji{font-size:32px;margin-bottom:12px}
.support-card h3{font-size:17px;font-weight:700;color:var(--brown);margin-bottom:8px}
.support-card p{font-size:14px;color:var(--text-sec);line-height:1.5}
.support-card a{color:var(--coral);font-weight:600}
@media(max-width:640px){.support-cards{grid-template-columns:1fr}}

.support-faq-category{margin-bottom:48px}
.support-faq-category h3{
  font-family:'Playfair Display',serif;
  font-size:20px;font-weight:700;
  color:var(--brown);margin-bottom:16px;
}

/* ====== BLOG PAGE ====== */
.blog-notice{
  text-align:center;padding:32px 0 48px;
}
.blog-notice .notice-box{
  display:inline-flex;flex-direction:column;align-items:center;
  background:var(--glass);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid var(--glass-border);
  border-radius:var(--radius);
  padding:32px 40px;
  max-width:520px;
  box-shadow:var(--shadow);
}
.blog-notice .notice-box p{
  color:var(--text-sec);font-size:15px;
  margin-bottom:20px;line-height:1.6;
}
.blog-notice .notice-form{
  display:flex;gap:12px;width:100%;
}
.blog-notice .notice-form input{flex:1;min-width:0;padding:12px 18px}
@media(max-width:500px){
  .blog-notice .notice-form{flex-direction:column}
  .blog-notice .notice-form .btn{width:100%}
}

.blog-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:24px;
  margin-bottom:64px;
}
.blog-card{overflow:hidden;position:relative}
.blog-card .blog-card-img{
  height:200px;
  background:linear-gradient(135deg,rgba(255,176,136,0.2),rgba(107,197,160,0.15));
  display:flex;align-items:center;justify-content:center;
  font-size:48px;
  border-radius:var(--radius) var(--radius) 0 0;
}
.blog-card .blog-card-body{padding:24px}
.blog-card .blog-card-badge{
  display:inline-block;
  padding:4px 12px;border-radius:999px;
  font-size:11px;font-weight:700;
  background:rgba(238,91,43,0.1);color:var(--coral);
  margin-bottom:12px;
}
.blog-card h3{font-size:18px;font-weight:700;color:var(--brown);margin-bottom:8px}
.blog-card p{font-size:14px;color:var(--text-sec);line-height:1.6}
@media(max-width:640px){.blog-grid{grid-template-columns:1fr}}

/* ====== FAQ (shared for support and index) ====== */
.faq-list{max-width:700px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq-item{padding:0;overflow:hidden;cursor:pointer}
.faq-q{
  padding:20px 24px;
  display:flex;align-items:center;justify-content:space-between;
  font-weight:700;font-size:16px;color:var(--brown);
}
.faq-q .arrow{
  font-size:20px;transition:transform 0.3s;color:var(--text-muted);
}
.faq-item.open .faq-q .arrow{transform:rotate(180deg)}
.faq-a{
  max-height:0;overflow:hidden;transition:max-height 0.4s ease,padding 0.3s ease;
  padding:0 24px;font-size:15px;color:var(--text-sec);line-height:1.7;
}
.faq-item.open .faq-a{max-height:300px;padding:0 24px 20px}
.faq-a a{color:var(--coral)}
