/* ============================================================
   180 Coffee Co. — styles
   ============================================================ */
:root{
  --pink:#c91e6d;
  --pink-dark:#b51a61;
  --pink-soft:#fdeef4;
  --pink-line:#f3c8db;
  --ink:#1b1417;
  --text:#241c1f;
  --body:#574a4f;
  --muted:#7a6a6f;
  --dot:#eccdda;
  --maxw:1200px;
  --display:'Outfit',system-ui,sans-serif;
  --sans:'Plus Jakarta Sans',system-ui,sans-serif;
  --script:'Caveat',cursive;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--sans);color:var(--text);
  background:#fff;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
input,select,textarea{font-family:inherit}
ul{margin:0;padding:0;list-style:none}
h1,h2,h3{margin:0}
::selection{background:var(--pink);color:#fff}
.ic{flex-shrink:0;display:inline-block;vertical-align:middle}
.ic-heart{display:inline-block;vertical-align:middle}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:700;border-radius:999px;transition:transform .2s,box-shadow .2s,background .2s}
.btn-pink{background:var(--pink);color:#fff;font-size:14.5px;padding:11px 22px;box-shadow:0 8px 22px rgba(201,30,109,.28)}
.btn-pink:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(201,30,109,.4)}
.btn-lg{font-size:16px;padding:16px 30px}
.btn-ghost{background:#fff;color:var(--pink);border:1.5px solid #f1bcd4}
.btn-ghost:hover{background:var(--pink-soft);transform:translateY(-3px)}
.btn-block{width:100%;justify-content:center;border:none;padding:16px;font-size:16px}
.eyebrow{font-size:12.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--pink)}

/* ---------- nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:80;border-bottom:1px solid rgba(201,30,109,0);transition:background .35s,box-shadow .35s,border-color .35s}
.nav.scrolled{background:rgba(255,255,255,.9);box-shadow:0 8px 30px rgba(201,30,109,.08);border-bottom-color:rgba(201,30,109,.1);backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px)}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:12px 24px;display:flex;align-items:center;justify-content:space-between;gap:20px;transition:padding .35s ease}
.nav.scrolled .nav-inner{padding:7px 24px}
.logo{width:300px;height:auto;transition:width .35s ease}
.nav.scrolled .logo{width:130px}
.nav-links{display:flex;align-items:center;gap:34px}
.nav-links>a{font-size:15px;font-weight:600;color:#33282c;transition:color .2s}
.nav-links>a:not(.btn):hover{color:var(--pink)}
.burger{display:none;flex-direction:column;gap:5px;background:#fff;border:1px solid rgba(201,30,109,.18);border-radius:12px;padding:11px 12px;box-shadow:0 6px 18px rgba(201,30,109,.1)}
.burger span{width:22px;height:2.5px;background:var(--pink);border-radius:2px;display:block;transition:transform .3s,opacity .3s}
.burger.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}
.drawer{display:none;flex-direction:column;gap:4px;padding:8px 24px 22px;background:rgba(255,255,255,.98);backdrop-filter:blur(14px);border-bottom:1px solid rgba(201,30,109,.12)}
.drawer.open{display:flex}
.drawer>a{padding:13px 6px;font-weight:600;font-size:17px;border-bottom:1px solid #f6e3ec}
.drawer .drawer-cta{margin-top:10px;justify-content:center;border-bottom:none;padding:14px}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;padding:188px 24px 70px;background:radial-gradient(120% 90% at 85% 0%,#fdeef4 0%,#fff 55%)}
.blob{position:absolute;pointer-events:none;animation:blob 13s ease-in-out infinite}
.blob-1{top:-60px;left:-90px;width:340px;height:340px;background:#fbd0e2;filter:blur(8px);opacity:.55;animation:blob 14s ease-in-out infinite,floaty 9s ease-in-out infinite}
.blob-2{bottom:-80px;right:6%;width:240px;height:240px;background:#fce0ec;filter:blur(6px);opacity:.6;animation:blob 11s ease-in-out infinite reverse}
.hero-grid{position:relative;max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;gap:54px;flex-wrap:wrap}
.hero-copy{flex:1 1 460px;min-width:300px}
.badge{display:inline-flex;align-items:center;gap:9px;background:#fff;border:1px solid #f4cfe0;border-radius:999px;padding:8px 16px;box-shadow:0 8px 22px rgba(201,30,109,.08);margin-bottom:26px;font-size:12.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--pink)}
.badge .dot{width:9px;height:9px;border-radius:50%;background:var(--pink);box-shadow:0 0 0 4px rgba(201,30,109,.16)}
.hero h1{font-family:var(--display);font-weight:800;font-size:clamp(42px,6.6vw,82px);line-height:.98;letter-spacing:-.025em;color:var(--ink);margin:0 0 22px}
.hl{position:relative;color:var(--pink);white-space:nowrap}
.underline{position:absolute;left:0;bottom:-8px;width:100%;height:12px}
.lead{font-size:clamp(16px,1.8vw,19px);line-height:1.6;color:#5d4f54;max-width:480px;margin:0 0 34px}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.hero-stats{display:flex;flex-wrap:wrap;gap:22px;margin-top:34px;align-items:center}
.stat{display:flex;align-items:center;gap:9px}
.stat .num{font-family:var(--display);font-weight:800;font-size:22px;color:var(--pink)}
.stat .lbl{font-size:13.5px;color:var(--muted);line-height:1.25}
.divider{width:1px;align-self:stretch;background:#f1d2df}
.hero-media{flex:1 1 400px;min-width:280px;position:relative;display:flex;justify-content:center}
.media-glow{position:absolute;inset:8% 12%;background:linear-gradient(150deg,#f7b6d2,var(--pink));filter:blur(4px);animation:blob 12s ease-in-out infinite;opacity:.9}
.media-frame{position:relative;width:min(380px,86vw);border-radius:30px;overflow:hidden;border:7px solid #fff;box-shadow:0 30px 60px rgba(201,30,109,.28);transform:rotate(2.4deg)}
.media-frame img{width:100%;height:100%;object-fit:cover}
.tag{position:absolute;box-shadow:0 14px 30px rgba(201,30,109,.2)}
.tag-fresh{top:2%;left:-2%;background:#fff;border-radius:18px;padding:10px 16px;transform:rotate(-7deg);animation:floaty2 6s ease-in-out infinite}
.tag-fresh span{font-family:var(--script);font-size:26px;font-weight:700;color:var(--pink)}
.tag-fav{bottom:6%;right:-3%;background:var(--ink);color:#fff;border-radius:16px;padding:11px 16px;box-shadow:0 14px 30px rgba(0,0,0,.22);animation:floaty 7s ease-in-out infinite}
.tag-fav-k{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:#f4a9c8;font-weight:700}
.tag-fav-t{font-family:var(--display);font-weight:700;font-size:16px}
.scroll-cue{display:flex;justify-content:center;margin-top:30px;font-size:24px;color:var(--pink);animation:arrow 1.6s ease-in-out infinite}

/* ---------- marquee ---------- */
.marquee{background:var(--pink);overflow:hidden;transform:rotate(-2deg);margin:18px -2% 0;width:104%;box-shadow:0 14px 36px rgba(201,30,109,.22)}
.marquee-track{display:flex;width:max-content;animation:mq 28s linear infinite;padding:16px 0}
.marquee-group{display:flex;align-items:center;gap:30px;padding-right:30px;font-family:var(--display);font-weight:700;font-size:clamp(18px,2.4vw,30px);text-transform:uppercase;letter-spacing:.02em;color:#fff;white-space:nowrap}
.marquee .star{color:#f7b6d2}

/* ---------- about ---------- */
.about{padding:clamp(74px,9vw,120px) 24px;background:#fff;scroll-margin-top:96px}
.about-grid{max-width:1140px;margin:0 auto;display:flex;gap:56px;align-items:center;flex-wrap:wrap}
.about-media{flex:1 1 380px;min-width:280px;position:relative}
.about-circle{position:absolute;top:-22px;left:-22px;width:120px;height:120px;border-radius:50%;background:var(--pink-soft);z-index:0}
.about-frame{position:relative;z-index:1;border-radius:26px;overflow:hidden;border:6px solid #fff;box-shadow:0 26px 54px rgba(40,20,30,.18)}
.about-frame img{width:100%;height:100%;object-fit:cover}
.about-pill{position:absolute;z-index:2;bottom:18px;left:50%;transform:translateX(-50%);background:#fff;border-radius:999px;padding:10px 18px;box-shadow:0 12px 28px rgba(40,20,30,.16);white-space:nowrap;display:inline-flex;align-items:center;gap:7px;font-size:13.5px;font-weight:600;color:#5d4f54}
.about-copy{flex:1 1 420px;min-width:300px}
.about-copy h2{font-family:var(--display);font-weight:800;font-size:clamp(30px,4.2vw,50px);line-height:1.04;letter-spacing:-.02em;color:var(--ink);margin:14px 0 0}
.about-copy p{font-size:17px;line-height:1.68;color:#574a4f;margin:22px 0 16px}
.about-copy p:nth-of-type(2){margin:0 0 22px}
.about-copy strong{color:var(--ink)}
.script{font-family:var(--script);font-size:30px;font-weight:700;color:var(--pink);margin:0 0 26px;transform:rotate(-2deg);display:flex;align-items:center;gap:6px}
.about-chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{display:inline-flex;align-items:center;gap:7px;background:var(--pink-soft);color:var(--pink-dark);font-weight:600;font-size:14px;padding:9px 16px;border-radius:999px;border:1px solid #f6d3e2}

/* ---------- menu ---------- */
.menu{padding:clamp(74px,9vw,120px) 24px;background:linear-gradient(180deg,#fff 0%,#fdeef4 30%,#fdeef4 100%);scroll-margin-top:96px}
.menu-wrap{max-width:1180px;margin:0 auto}
.menu-head{text-align:center;max-width:640px;margin:0 auto 18px}
.menu-head h2{font-family:var(--display);font-weight:800;font-size:clamp(32px,5vw,58px);line-height:1;letter-spacing:-.02em;color:var(--ink);margin:12px 0 14px}
.menu-head p{font-size:16.5px;line-height:1.6;color:#6a5b60;margin:0}
.chip-bar{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin:30px 0 40px;position:sticky;top:84px;z-index:30}
.mchip{font-weight:600;font-size:14px;padding:10px 18px;border-radius:999px;background:#fff;color:var(--pink-dark);border:1.5px solid var(--pink-line);transition:all .2s}
.mchip:hover{border-color:var(--pink)}
.mchip.active{background:var(--pink);color:#fff;border-color:var(--pink);box-shadow:0 8px 20px rgba(201,30,109,.2)}
.menu-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:22px;align-items:start}
.mcard{scroll-margin-top:150px;background:#fff;border-radius:24px;padding:30px 28px;box-shadow:0 18px 44px rgba(201,30,109,.09);border:1px solid #f7dbe8}
.mcard-head{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.mcard-head h3{font-family:var(--display);font-weight:700;font-size:24px;color:var(--ink);letter-spacing:-.01em}
.mcard-desc{font-size:13.5px;color:#8a7378;margin:0 0 18px;line-height:1.5}
.rows{display:flex;flex-direction:column;gap:11px}
.row{display:flex;align-items:baseline;gap:8px}
.row .name{font-weight:600;color:#33282c;font-size:15.5px}
.row .dots{flex:1;border-bottom:1.5px dotted var(--dot)}
.row .dots-d{border-bottom-color:#5a4750}
.row .price{font-family:var(--display);font-weight:700;color:var(--pink)}
.row .price-l{color:#f7b6d2}
.mcard-dark{background:var(--ink);border:none;padding:0;overflow:hidden;box-shadow:0 22px 50px rgba(27,20,23,.28);display:flex;flex-direction:column}
.mcard-photo{position:relative;height:180px;overflow:hidden}
.mcard-photo img{width:100%;height:100%;object-fit:cover}
.mcard-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(27,20,23,0) 40%,rgba(27,20,23,.85) 100%)}
.photo-tag{position:absolute;z-index:1;top:14px;left:14px;background:var(--pink);color:#fff;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:6px 12px;border-radius:999px}
.mcard-body{padding:26px 28px 30px}
.mcard-dark .mcard-head h3{color:#fff}
.mcard-dark .mcard-desc{color:#d9b8c6}
.mcard-dark .mcard-desc em{color:#f7b6d2;font-style:normal}
.mcard-dark .row .name{color:#f4e7ec}
.addons{margin-top:24px;background:var(--pink);border-radius:24px;padding:26px 30px;display:flex;flex-wrap:wrap;align-items:center;gap:18px 30px;box-shadow:0 18px 44px rgba(201,30,109,.22)}
.addons-title{display:flex;align-items:center;gap:12px;font-family:var(--display);font-weight:700;font-size:21px;color:#fff}
.addons-list{display:flex;flex-wrap:wrap;gap:10px 12px;flex:1}
.addons-list span{background:rgba(255,255,255,.16);color:#fff;font-weight:600;font-size:14px;padding:9px 16px;border-radius:999px}

/* ---------- events ---------- */
.events{padding:clamp(74px,9vw,120px) 24px;background:#fff;scroll-margin-top:96px}
.events-wrap{max-width:1140px;margin:0 auto}
.events-head{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:42px}
.events-head h2{font-family:var(--display);font-weight:800;font-size:clamp(30px,4.4vw,52px);line-height:1.02;letter-spacing:-.02em;color:var(--ink);margin:12px 0 0}
.events-note{font-size:15px;color:var(--muted);max-width:300px;line-height:1.55;margin:0}
.events-note strong{color:var(--pink)}
.events-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px}
.event{background:#fff;border:1.5px solid #f4cfe0;border-radius:20px;padding:22px;display:flex;gap:16px;align-items:flex-start;box-shadow:0 12px 30px rgba(201,30,109,.07);transition:transform .25s,box-shadow .25s,border-color .25s}
.event:hover{transform:translateY(-5px);box-shadow:0 20px 40px rgba(201,30,109,.16);border-color:var(--pink)}
.event-priv{background:#faf4f7;border-color:#efdfe7;box-shadow:none}
.event-priv:hover{transform:translateY(-5px);box-shadow:none;border-color:#efdfe7}
.date{flex-shrink:0;width:62px;text-align:center;border-radius:14px;padding:10px 0;color:#fff}
.date-pink{background:var(--pink)}
.date-dark{background:var(--ink)}
.date .m{display:block;font-size:11px;font-weight:700;letter-spacing:.1em}
.date .d{display:block;font-family:var(--display);font-weight:800;font-size:26px;line-height:1}
.date .d-sm{font-size:21px;line-height:1.05}
.status{display:inline-flex;align-items:center;gap:5px;font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:4px 9px;border-radius:999px;margin-bottom:7px}
.status-open{background:#e9fbef;color:#1f9d52}
.status-priv{background:#f1e2ea;color:var(--pink-dark)}
.event-body h3{font-family:var(--display);font-weight:700;font-size:18px;color:var(--ink);margin:0 0 4px}
.event-body p{font-size:13.5px;color:var(--muted);margin:0}
.event-priv .event-body p{color:#9a8a8f}
.events-highlight{margin-top:32px;display:flex;align-items:center;justify-content:center;gap:16px;text-align:center;background:var(--pink-soft);border:1.5px solid var(--pink-line);border-radius:20px;padding:22px 28px}
.events-highlight .ic-badge{width:46px;height:46px;border-radius:14px;background:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 8px 20px rgba(201,30,109,.12)}
.events-highlight p{margin:0;font-family:var(--display);font-weight:600;font-size:clamp(17px,2.2vw,21px);letter-spacing:-.01em;color:var(--ink)}
.events-highlight strong{color:var(--pink)}
@media(max-width:480px){.events-highlight{flex-direction:column;gap:12px}}

/* ---------- book ---------- */
.book{padding:clamp(74px,9vw,120px) 24px;background:linear-gradient(180deg,#fdeef4 0%,#fff 100%);scroll-margin-top:96px}
.book-grid{max-width:1100px;margin:0 auto;display:flex;gap:40px;flex-wrap:wrap}
.book-intro{flex:1 1 300px;min-width:280px}
.book-intro h2{font-family:var(--display);font-weight:800;font-size:clamp(30px,4.4vw,50px);line-height:1.02;letter-spacing:-.02em;color:var(--ink);margin:12px 0 16px;display:flex;align-items:center;flex-wrap:wrap;gap:8px}
.book-lead{font-size:16.5px;line-height:1.6;color:#5d4f54;margin:0 0 28px;max-width:380px}
.book-chips{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:30px}
.bchip{display:inline-flex;align-items:center;gap:7px;background:#fff;color:var(--pink-dark);font-weight:600;font-size:13.5px;padding:8px 15px;border-radius:999px;border:1px solid var(--pink-line)}
.contact{display:flex;flex-direction:column;gap:14px}
.contact-row{display:flex;align-items:center;gap:13px;transition:opacity .2s}
.contact-row:hover{opacity:.85}
.contact-ic{width:42px;height:42px;border-radius:12px;background:var(--pink-soft);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.contact-k{display:block;font-size:11.5px;color:#9a8a8f;font-weight:600;text-transform:uppercase;letter-spacing:.08em}
.contact-v{font-weight:700;color:var(--ink);font-size:15.5px}
.book-form-wrap{flex:1 1 380px;min-width:300px}
.book-form,.book-success{background:#fff;border-radius:26px;box-shadow:0 24px 54px rgba(201,30,109,.14);border:1px solid #f6d9e6}
.book-form{padding:32px 30px}
.book-form-embed{padding:34px 20px 22px}
.book-form h3{font-family:var(--display);font-weight:700;font-size:21px;color:var(--ink);margin:0 0 20px}
.fields{display:flex;flex-direction:column;gap:16px}
.field{display:block}
.field-label{display:block;font-size:13px;font-weight:600;color:#5d4f54;margin-bottom:7px}
.field-label .opt{color:#b09aa1;font-weight:500}
.field input,.field select,.field textarea{width:100%;padding:13px 15px;border-radius:13px;border:1.5px solid #eed7e1;font-size:15px;background:#fffdfe;outline:none;color:#33282c;transition:border-color .2s}
.field textarea{resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--pink)}
.field input.invalid,.field select.invalid{border-color:var(--pink)}
.field-row{display:flex;gap:14px;flex-wrap:wrap}
.field-row .field{flex:1 1 150px}
.error{display:block;font-size:12.5px;color:var(--pink);margin-top:6px;font-weight:600;min-height:0}
.form-foot{font-size:12px;color:#a89399;text-align:center;margin:2px 0 0}
.book-success{padding:48px 34px;text-align:center}
.success-ic{width:74px;height:74px;border-radius:50%;background:var(--pink-soft);display:flex;align-items:center;justify-content:center;margin:0 auto 20px}
.book-success h3{font-family:var(--display);font-weight:800;font-size:27px;color:var(--ink);margin:0 0 10px}
.book-success p{font-size:16px;line-height:1.6;color:#5d4f54;margin:0 0 8px}
.success-sub{font-size:14px;color:#9a8a8f}
.success-sub strong{color:var(--pink)}

/* ---------- footer ---------- */
.footer{background:var(--pink);color:#fff;padding:60px 24px 30px}
.footer-top{max-width:1140px;margin:0 auto;display:flex;flex-wrap:wrap;gap:40px;justify-content:space-between}
.footer-brand{flex:1 1 280px;max-width:360px}
.footer-logo{width:300px;max-width:100%;height:auto;margin-bottom:18px}
.footer-brand p{font-size:15px;line-height:1.6;color:#fbe0ec;margin:0}
.footer-cols{display:flex;gap:54px;flex-wrap:wrap}
.footer-h{font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#f7b6d2;margin-bottom:14px}
.footer-col{display:flex;flex-direction:column;gap:10px;font-size:15px}
.footer-col>a:hover{color:#fbe0ec}
.footer-social{display:inline-flex;align-items:center;gap:9px}
.footer-bottom{max-width:1140px;margin:42px auto 0;padding-top:22px;border-top:1px solid rgba(255,255,255,.22);display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;align-items:center}
.footer-bottom>span:first-child{font-size:13px;color:#fbe0ec}
.footer-bottom a{font-weight:600;text-decoration:underline;text-underline-offset:2px}
.footer-bottom a:hover{color:#fbe0ec}
.footer-script{font-family:var(--script);font-size:22px;color:#fff}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .9s cubic-bezier(.16,.84,.3,1),transform .9s cubic-bezier(.16,.84,.3,1)}
.reveal.in{opacity:1;transform:none}

/* ---------- keyframes ---------- */
@keyframes mq{to{transform:translateX(-50%)}}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-16px)}}
@keyframes floaty2{0%,100%{transform:translateY(0) rotate(-9deg)}50%{transform:translateY(-12px) rotate(-9deg)}}
@keyframes blob{0%,100%{border-radius:44% 56% 60% 40%/52% 44% 56% 48%}50%{border-radius:58% 42% 40% 60%/44% 58% 42% 56%}}
@keyframes arrow{0%,100%{transform:translateY(0);opacity:.45}50%{transform:translateY(9px);opacity:1}}

/* ---------- responsive ---------- */
@media(max-width:820px){
  .nav-links{display:none}
  .burger{display:flex}
  .hero{padding-top:120px}
  .logo{width:230px}
  .nav.scrolled .logo{width:150px}
}
@media(max-width:560px){
  .logo{width:200px}
  .hero h1{font-size:clamp(38px,11vw,56px)}
  .footer-logo{width:230px}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important}
  .reveal{transition:none}
  html{scroll-behavior:auto}
}
