/* ===========================================================
   Fullhouse — וילות לפי אירוע · home page
   Warm · rounded · young — Rubik + Heebo, amber/olive/sand
   =========================================================== */

:root{
  --amber-600:#F4C636;   /* primary — bright butter yellow */
  --amber-700:#E6AC1C;   /* hover/press */
  --amber-800:#A8780E;   /* readable yellow on light bg (eyebrow/links/tags) */
  --amber-300:#FBDC72;
  --amber-100:#FCEEC2;
  --amber-50:#FEF8E7;

  --olive-700:#525C36;
  --olive-600:#6B764A;
  --olive-100:#E8EAD8;

  --mustard:#F4C740;     /* cheerful yellow — swoosh & stars */

  --sand-50:#FBF6EC;     /* page bg */
  --sand-100:#F4EAD9;
  --sand-200:#ECDFC8;
  --cream:#FFFDF8;       /* cards */

  --ink-900:#2C261E;
  --ink-700:#4B4238;
  --ink-500:#7A6F61;
  --ink-300:#A89C8C;
  --line:#EADFCC;
  --line-soft:#F0E7D6;

  /* event hues — distinct, lively, no two alike */
  --t-rovakot:#E26D6D;   /* bachelorette — rose */
  --t-bday:#EE9F3A;      /* birthday — tangerine */
  --t-team:#2E9B8F;      /* team — teal */
  --t-family:#4E86C4;    /* family — sky blue */
  --t-romance:#C2557A;   /* romance — deep pink */
  --t-quiet:#6E8270;     /* quiet — muted sage */

  --r-sm:12px;
  --r-md:18px;
  --r-lg:26px;
  --r-xl:34px;
  --r-2xl:44px;

  --shadow-xs:0 1px 3px rgba(60,42,24,.06);
  --shadow-sm:0 2px 8px rgba(60,42,24,.06), 0 10px 28px rgba(60,42,24,.05);
  --shadow-md:0 8px 20px rgba(60,42,24,.10), 0 22px 56px rgba(60,42,24,.08);
  --shadow-lg:0 16px 40px rgba(60,42,24,.16), 0 40px 90px rgba(60,42,24,.12);

  --serif:"Rubik", system-ui, sans-serif;  /* headlines */
  --sans:"Heebo", system-ui, sans-serif;   /* body & ui */

  --ease:cubic-bezier(.2,.7,.2,1);
  --maxw:1240px;
}

*{box-sizing:border-box; margin:0; padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--sans);
  background:var(--sand-50);
  color:var(--ink-900);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block; max-width:100%;}
button{font-family:inherit; cursor:pointer;}
a{color:inherit; text-decoration:none;}

.wrap{max-width:var(--maxw); margin:0 auto; padding:0 28px;}
@media(max-width:640px){ .wrap{padding:0 18px;} }

h1,h2,h3,h4{font-family:var(--serif); font-weight:700; line-height:1.1; letter-spacing:-.01em; color:var(--ink-900);}
.eyebrow{font-size:13px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--amber-800);}

/* reveal-on-scroll */
.reveal{opacity:0; transform:translateY(18px); transition:opacity .6s var(--ease), transform .6s var(--ease);}
.reveal.in{opacity:1; transform:none;}
/* hard fallback: forces final state with no transition, so visibility never
   depends on the animation clock advancing (e.g. throttled/background tabs) */
.reveal.snap{transition:none !important; opacity:1 !important; transform:none !important;}

/* ============ HEADER ============ */
.hdr{
  position:sticky; top:0; z-index:60;
  background:rgba(251,246,236,.82);
  backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid transparent;
  transition:border-color .25s var(--ease), background .25s var(--ease);
}
.hdr.scrolled{border-bottom-color:var(--line); background:rgba(251,246,236,.94);}
.hdr-inner{height:74px; display:flex; align-items:center; justify-content:space-between; gap:20px;}
.logo{display:flex; align-items:center; gap:11px; font-family:var(--serif); font-weight:800; font-size:23px; color:var(--ink-900);}
.logo .mark{width:38px; height:38px; border-radius:13px; background:linear-gradient(135deg,var(--amber-600),var(--mustard)); display:grid; place-items:center; box-shadow:0 4px 12px rgba(214,164,28,.34); flex:none; transition:transform .5s var(--ease);}
.logo:hover .mark{transform:rotate(-12deg);}
.logo .mark svg{width:22px; height:22px; stroke:#fff; fill:none; stroke-width:2; stroke-linecap:round; stroke-linejoin:round;}
.logo b{font-weight:800;}
.logo .mark + span span{color:var(--amber-800);}

.nav{display:flex; align-items:center; gap:6px;}
.nav a{padding:9px 15px; border-radius:999px; font-size:15.5px; font-weight:500; color:var(--ink-700); transition:background .15s var(--ease), color .15s var(--ease);}
.nav a:hover{background:var(--sand-200); color:var(--ink-900);}
.hdr-actions{display:flex; align-items:center; gap:10px;}
.btn{font-family:var(--sans); font-weight:600; border:none; border-radius:999px; transition:all .18s var(--ease); white-space:nowrap;}
.btn-primary{background:var(--ink-900); color:var(--sand-50); padding:12px 22px; font-size:15px;}
.btn-primary:hover{background:#1d1813;}
.btn-amber{background:var(--amber-600); color:#3a2a08; padding:13px 26px; font-size:16px; box-shadow:0 6px 16px rgba(214,164,28,.30);}
.btn-amber:hover{background:var(--amber-700); color:#3a2a08; box-shadow:0 4px 12px rgba(214,164,28,.40);}
.btn-ghost{background:transparent; color:var(--ink-900); padding:11px 18px; font-size:15px; border:1.5px solid var(--line);}
.btn-ghost:hover{border-color:var(--amber-600); color:var(--amber-800);}
.hamburger{display:none; width:44px; height:44px; border-radius:12px; border:1.5px solid var(--line); background:var(--cream); align-items:center; justify-content:center;}
.hamburger svg{width:22px; height:22px; stroke:var(--ink-900); stroke-width:2;}

/* ============ HERO ============ */
.hero{position:relative; padding:54px 0 22px;}
.hero-grid{display:grid; gap:40px; align-items:center;}
.hero-copy{max-width:620px;}
.hero h1{font-size:clamp(40px,6vw,72px); font-weight:800; letter-spacing:-.02em;}
.hero h1 .hl{color:var(--ink-900); position:relative; white-space:nowrap;}
.hero h1 .hl svg{position:absolute; left:-2%; right:-2%; bottom:-.18em; width:104%; height:.36em; stroke:var(--mustard); fill:none; stroke-width:9; stroke-linecap:round;}
.hero .sub{margin-top:20px; font-size:clamp(17px,2.2vw,20px); color:var(--ink-500); max-width:46ch;}

/* search */
.searchwrap{position:relative; margin-top:34px; max-width:760px;}
.searchbar{
  display:flex; align-items:stretch; background:var(--cream);
  border-radius:999px; box-shadow:var(--shadow-md);
  border:1px solid var(--line-soft); padding:7px;
}
.sfield{flex:1; position:relative; display:flex; flex-direction:column; justify-content:center; padding:11px 22px; border-radius:999px; cursor:pointer; transition:background .15s var(--ease); min-width:0;}
.sfield:hover{background:var(--sand-100);}
.sfield.active{background:var(--sand-100);}
.sfield + .sfield::before{content:""; position:absolute; right:0; top:50%; transform:translateY(-50%); height:30px; width:1px; background:var(--line);}
.sfield .lab{font-size:12.5px; font-weight:700; color:var(--ink-900);}
.sfield .val{font-size:14.5px; color:var(--ink-500); font-weight:500; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;}
.sfield .val.filled{color:var(--ink-900); font-weight:600;}
.sfield.celebrate{flex:1.35;}
.sfield.celebrate .lab{color:var(--amber-800);}
.search-go{flex:none; width:60px; border-radius:999px; background:var(--amber-600); color:#3a2a08; border:none; display:grid; place-items:center; margin-inline-start:4px; transition:all .18s var(--ease);}
.search-go:hover{background:var(--amber-700); color:#3a2a08;}
.search-go:hover svg{transform:rotate(-12deg);}
.search-go svg{width:24px; height:24px; stroke:currentColor; fill:none; stroke-width:2.4; stroke-linecap:round; stroke-linejoin:round; transition:transform .35s var(--ease);}

/* playful bubble */
.bubble{
  position:absolute; top:-30px; inset-inline-start:6px; z-index:5;
  background:var(--ink-900); color:var(--sand-50);
  font-size:13.5px; font-weight:600; padding:9px 15px; border-radius:14px 14px 14px 4px;
  box-shadow:var(--shadow-sm); animation:bob 3.2s var(--ease) infinite;
  display:flex; align-items:center; gap:7px;
}
.bubble .spark{width:15px; height:15px; stroke:var(--mustard); fill:none; stroke-width:2;}
.bubble::after{content:""; position:absolute; bottom:-7px; inset-inline-start:18px; width:14px; height:14px; background:var(--ink-900); border-radius:0 0 0 4px; transform:rotate(45deg) skew(-6deg,-6deg);}
@keyframes bob{0%,100%{transform:translateY(0) rotate(-1.5deg);}50%{transform:translateY(-6px) rotate(-1.5deg);}}

/* dropdown for "what are you celebrating" */
.dropdown{
  position:absolute; top:calc(100% + 12px); inset-inline-start:0; z-index:40;
  width:min(420px,90vw); background:var(--cream); border-radius:var(--r-lg);
  box-shadow:var(--shadow-lg); border:1px solid var(--line-soft); padding:10px;
  opacity:0; transform:translateY(-8px) scale(.98); pointer-events:none;
  transition:opacity .2s var(--ease), transform .2s var(--ease);
}
.dropdown.open{opacity:1; transform:none; pointer-events:auto;}
.dd-title{font-size:12px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-300); padding:8px 12px 4px;}
.dd-opt{display:flex; align-items:center; gap:13px; padding:11px 12px; border-radius:14px; cursor:pointer; transition:background .12s var(--ease);}
.dd-opt:hover{background:var(--sand-100);}
.dd-ic{width:40px; height:40px; border-radius:12px; flex:none; display:grid; place-items:center;}
.dd-ic svg{width:21px; height:21px; stroke:#fff; fill:none; stroke-width:1.9; stroke-linecap:round; stroke-linejoin:round;}
.dd-opt .nm{font-weight:600; font-size:16px;}
.dd-opt .ds{font-size:13px; color:var(--ink-500);}

/* secondary field dropdowns (where / when), anchored under their own field */
.sfield .dropdown{width:min(300px,84vw);}
.sfield.where .dropdown{inset-inline-start:0; inset-inline-end:auto;}
.sfield.when .dropdown{inset-inline-end:0; inset-inline-start:auto;}
.dd-opt.simple .dd-mini{width:36px; height:36px; border-radius:11px; flex:none; display:grid; place-items:center; background:var(--sand-100); transition:background .12s var(--ease);}
.dd-opt.simple .dd-mini svg{width:18px; height:18px; stroke:var(--ink-700); fill:none; stroke-width:1.9; stroke-linecap:round; stroke-linejoin:round;}
.dd-opt.simple:hover .dd-mini,.dd-opt.simple.sel .dd-mini{background:var(--amber-100);}
.dd-opt.simple.sel .dd-mini svg{stroke:var(--amber-800);}
.dd-opt.simple .nm{font-weight:600; font-size:15.5px;}

/* date calendar inside the "when" dropdown */
.sfield.when .dropdown{width:min(620px,94vw);}
.cal{padding:2px 4px 4px;}
.cal-grid{display:flex; gap:18px;}
.cal-month{flex:1 1 0; min-width:0;}
.cal-nav-spacer{width:32px; height:32px;}
.cal-head{display:flex; align-items:center; justify-content:space-between; padding:2px 4px 10px;}
.cal-title{font-weight:700; font-size:15px; color:var(--ink-900); font-family:var(--sans);}
.cal-nav{width:32px; height:32px; border-radius:9px; border:1px solid var(--line); background:var(--cream); display:grid; place-items:center; cursor:pointer; transition:background .12s var(--ease), border-color .12s var(--ease);}
.cal-nav:hover:not(:disabled){background:var(--sand-100); border-color:var(--amber-300);}
.cal-nav:disabled{opacity:.32; cursor:default;}
.cal-nav svg{width:18px; height:18px; stroke:var(--ink-700); fill:none; stroke-width:2.2; stroke-linecap:round; stroke-linejoin:round;}
.cal-dow{display:grid; grid-template-columns:repeat(7,1fr); gap:2px; margin-bottom:3px;}
.cal-dow span{text-align:center; font-size:11.5px; font-weight:700; color:var(--ink-300); padding:3px 0;}
.cal-days{display:grid; grid-template-columns:repeat(7,1fr); gap:2px 0;}
.cal-pad{height:38px;}
.cal-day{height:38px; border:none; background:transparent; border-radius:9px; font-family:var(--sans); font-size:14px; font-weight:600; color:var(--ink-900); cursor:pointer; transition:background .12s var(--ease), color .12s var(--ease);}
.cal-day:hover:not(:disabled):not(.sel){background:var(--sand-100);}
.cal-day.past{color:var(--ink-300); opacity:.45; cursor:default;}
.cal-day.in-range{background:var(--amber-100); border-radius:0;}
.cal-day.sel{background:var(--amber-600); color:#3a2a08;}
.cal-day.sel-single{border-radius:9px;}
.cal-day.sel-start{border-radius:0 9px 9px 0;}
.cal-day.sel-end{border-radius:9px 0 0 9px;}
.cal-hint{margin-top:8px; padding:8px 6px 2px; font-size:12.5px; color:var(--ink-500); text-align:center; border-top:1px solid var(--line-soft);}
@media (max-width:560px){ .cal-grid{flex-direction:column; gap:10px;} }

/* hero image */
.hero-photo{position:relative;}
.hero-photo image-slot{width:100%; height:clamp(320px,40vw,500px); display:block; border-radius:var(--r-2xl); box-shadow:var(--shadow-md);}
.hero-photo .floatchip{
  position:absolute; inset-inline-start:-14px; bottom:26px;
  background:var(--cream); border-radius:18px; padding:13px 18px; box-shadow:var(--shadow-md);
  display:flex; align-items:center; gap:12px;
}
.hero-photo .floatchip .big{font-family:var(--serif); font-weight:800; font-size:24px; color:var(--ink-900); line-height:1;}
.hero-photo .floatchip .sm{font-size:13px; color:var(--ink-500);}
.hero-photo .floatchip .av{display:flex;}
.hero-photo .floatchip .av i{width:30px; height:30px; border-radius:50%; border:2px solid var(--cream); margin-inline-start:-9px; display:block;}

/* warm gradient placeholders behind image-slots */
.ph{background-size:cover;}
.ph1{background:linear-gradient(150deg,#E6C277,#C26A4A 60%,#A85F5A);}
.ph2{background:linear-gradient(150deg,#A6B07A,#6B764A);}
.ph3{background:linear-gradient(150deg,#E6C277,#CC8E36);}
.ph4{background:linear-gradient(150deg,#C8896A,#A85F5A);}
.ph5{background:linear-gradient(150deg,#B7C089,#5E6B42);}
.ph6{background:linear-gradient(150deg,#E8CE8E,#B07A1E);}

/* ============ GOAL TILES ============ */
.section{padding:64px 0;}
.section.tight{padding:40px 0;}
.sec-head{display:flex; align-items:flex-end; justify-content:space-between; gap:20px; margin-bottom:28px; flex-wrap:wrap;}
.sec-head h2{font-size:clamp(26px,3.6vw,38px);}
.sec-head .sub{color:var(--ink-500); font-size:16px; margin-top:6px;}
.sec-head .link{font-weight:600; color:var(--amber-800); font-size:15px; display:inline-flex; align-items:center; gap:6px;}
.sec-head .link svg{width:17px; height:17px; stroke:currentColor; fill:none; stroke-width:2.2;}

.tiles{display:grid; grid-template-columns:repeat(6,1fr); gap:16px;}
.tile{
  position:relative; border-radius:var(--r-2xl); aspect-ratio:3/4; overflow:hidden;
  display:flex; flex-direction:column; justify-content:flex-end; padding:18px;
  color:#fff; cursor:pointer; transition:transform .3s var(--ease), box-shadow .3s var(--ease);
  box-shadow:var(--shadow-sm);
}
.tile .tile-bg{position:absolute; inset:0; z-index:0; width:100%; height:100%; display:block; border-radius:inherit;}
/* color veil tinting the photo to the event's feeling */
.tile .tint{position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(155deg,
    color-mix(in srgb, var(--c) 58%, transparent),
    color-mix(in srgb, var(--c) 28%, transparent));}
/* bottom shade for text legibility */
.tile::after{content:""; position:absolute; inset:0; z-index:2; pointer-events:none;
  background:linear-gradient(to top,rgba(20,12,4,.55),transparent 58%);}
.tile:hover{transform:translateY(-6px); box-shadow:var(--shadow-md);}
.tile .ic{position:relative; z-index:3; width:48px; height:48px; border-radius:14px; background:rgba(255,255,255,.22); display:grid; place-items:center; backdrop-filter:blur(2px); margin-bottom:auto; transition:transform .4s var(--ease);}
.tile:hover .ic{transform:rotate(-12deg) scale(1.06);}
.tile .ic svg{width:26px; height:26px; stroke:#fff; fill:none; stroke-width:1.9; stroke-linecap:round; stroke-linejoin:round;}
.tile .nm{position:relative; z-index:3; font-family:var(--serif); font-weight:700; font-size:20px; line-height:1.1; text-shadow:0 1px 8px rgba(0,0,0,.28);}
.tile .cnt{position:relative; z-index:3; font-size:13px; opacity:.95; margin-top:3px; text-shadow:0 1px 6px rgba(0,0,0,.3);}

/* ============ PROMISES (Bordo) ============ */
.promises{background:var(--cream); border-top:1px solid var(--line-soft); border-bottom:1px solid var(--line-soft);}
.promise-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:22px;}
.promise{text-align:center; padding:14px;}
.promise .ring{width:84px; height:84px; margin:0 auto 16px; border-radius:50%; border:2px solid var(--amber-300); display:grid; place-items:center; transition:transform .6s var(--ease), border-color .3s var(--ease), background .3s var(--ease);}
.promise:hover .ring{transform:rotate(18deg); border-color:var(--amber-600); background:var(--amber-50);}
.promise .ring svg{width:36px; height:36px; stroke:var(--amber-700); fill:none; stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round; transition:transform .6s var(--ease);}
.promise:hover .ring svg{transform:rotate(-18deg);}
.promise h4{font-size:18px; font-weight:700; margin-bottom:5px;}
.promise p{font-size:14px; color:var(--ink-500); line-height:1.55;}

/* ============ COLLECTIONS ============ */
.rail{display:flex; gap:20px; overflow-x:auto; padding:6px 28px 20px; scroll-snap-type:x mandatory; scrollbar-width:none;}
.rail::-webkit-scrollbar{display:none;}
.rail-wrap{max-width:var(--maxw); margin:0 auto;}
.coll{flex:none; width:300px; scroll-snap-align:start; cursor:pointer;}
.coll image-slot{width:100%; height:200px; display:block; border-radius:var(--r-lg); box-shadow:var(--shadow-sm); transition:box-shadow .25s var(--ease), transform .3s var(--ease);}
.coll:hover image-slot{box-shadow:var(--shadow-md); transform:translateY(-5px);}
.coll .label{margin-top:14px;}
.coll .label h4{font-size:19px; font-weight:700;}
.coll .label p{font-size:14px; color:var(--ink-500);}

/* ============ FEATURED GRID ============ */
.grid-cards{display:grid; grid-template-columns:repeat(3,1fr); gap:26px;}
.vcard{background:var(--cream); border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-sm); transition:transform .25s var(--ease), box-shadow .25s var(--ease);}
.vcard:hover{transform:translateY(-5px); box-shadow:var(--shadow-md);}
.vcard .pic{position:relative; overflow:hidden;}
.vcard .pic image-slot{width:100%; height:240px; display:block; border-radius:0; transition:transform .5s var(--ease);}
.vcard:hover .pic image-slot{transform:scale(1.05);}
.vcard .rate{position:absolute; top:14px; inset-inline-end:14px; z-index:3; background:rgba(255,253,248,.95); border-radius:999px; padding:6px 12px; font-weight:700; font-size:14px; display:flex; align-items:center; gap:5px; box-shadow:var(--shadow-xs); white-space:nowrap;}
.vcard .rate .star{color:var(--mustard);}
.vcard .rate .n{color:var(--ink-900);}
.vcard .rate .c{color:var(--ink-500); font-weight:500; font-size:12.5px;}
.vcard .fav{position:absolute; top:14px; inset-inline-start:14px; z-index:3; width:40px; height:40px; border-radius:50%; background:rgba(255,253,248,.9); display:grid; place-items:center; transition:transform .18s var(--ease);}
.vcard .fav:hover{transform:scale(1.1);}
.vcard .fav svg{width:20px; height:20px; stroke:var(--ink-700); fill:none; stroke-width:2; transition:all .18s var(--ease);}
.vcard .fav.on svg{fill:var(--t-romance); stroke:var(--t-romance);}
.vcard .body{padding:18px 20px 22px;}
.vcard .perfect{display:inline-flex; align-items:center; gap:6px; background:var(--amber-100); color:var(--amber-800); font-size:12.5px; font-weight:700; padding:5px 11px; border-radius:999px; margin-bottom:10px;}
.vcard .perfect svg{width:14px; height:14px; stroke:currentColor; fill:none; stroke-width:2; transition:transform .4s var(--ease);}
.vcard:hover .perfect svg{transform:rotate(-14deg);}
.vcard h4{font-size:21px; font-weight:700; margin-bottom:3px;}
.vcard .loc{font-size:14px; color:var(--ink-500); display:flex; align-items:center; gap:5px;}
.vcard .loc svg{width:15px; height:15px; stroke:var(--ink-300); fill:none; stroke-width:2;}
.vcard .ftr{display:flex; align-items:center; justify-content:space-between; gap:12px; margin-top:18px;}
.vcard .price b{font-family:var(--serif); font-weight:700; font-size:22px; color:var(--ink-900);}
.vcard .price span{font-size:13px; color:var(--ink-500);}
.vcard .book{background:var(--amber-600); color:#3a2a08; border:none; border-radius:999px; padding:11px 18px; font-weight:700; font-size:15px; transition:all .18s var(--ease); display:inline-flex; align-items:center; gap:7px; white-space:nowrap;}
.vcard .book .wa{width:16px; height:16px; flex:none; fill:currentColor; stroke:none; opacity:.92;}
.vcard .book:hover{background:var(--amber-700); color:#3a2a08;}
.vcard .book:hover .wa{opacity:1;}

/* ============ HOW IT WORKS ============ */
.how{background:linear-gradient(150deg,#322A20,#221C14); color:#fff; border-radius:var(--r-2xl); padding:54px clamp(24px,5vw,64px); position:relative; overflow:hidden; text-align:center;}
.how::before{content:""; position:absolute; inset-inline-end:-80px; top:-80px; width:300px; height:300px; border-radius:50%; background:rgba(244,198,54,.10);}
.how .eyebrow{color:var(--amber-300);}
.how h2{color:#fff; font-size:clamp(26px,3.4vw,36px); margin:10px auto 44px; max-width:20ch;}
.steps{display:flex; justify-content:center; align-items:flex-start; gap:56px;}
.step{position:relative; flex:1 1 0; max-width:250px; text-align:center;}
.step .num{width:50px; height:50px; border-radius:50%; background:rgba(255,255,255,.12); display:grid; place-items:center; font-family:var(--serif); font-weight:800; font-size:20px; color:var(--amber-300); margin:0 auto 16px; position:relative; z-index:1; transition:transform .3s var(--ease), background .3s var(--ease);}
.step:hover .num{transform:scale(1.09); background:rgba(244,198,54,.22);}
.step:not(:last-child)::after{
  content:""; position:absolute; top:25px; transform:translateY(-50%);
  inset-inline-end:-56px; width:56px; height:16px;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='16' viewBox='0 0 24 16' fill='none' stroke='%23F4C636' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M13 3 7 8l6 5'/%3E%3Cpath d='M21 3l-6 5 6 5'/%3E%3C/svg%3E") repeat-x;
  background-size:22px 16px;
  -webkit-mask:linear-gradient(to left,transparent,#000 26%,#000 74%,transparent);
          mask:linear-gradient(to left,transparent,#000 26%,#000 74%,transparent);
  animation:stepFlow 1.15s linear infinite;
}
@keyframes stepFlow{from{background-position:0 0;}to{background-position:-22px 0;}}
@media(prefers-reduced-motion:reduce){.step:not(:last-child)::after{animation:none;}}
.step h4{color:#fff; font-size:19px; margin-bottom:6px;}
.step p{color:rgba(255,255,255,.78); font-size:15px; line-height:1.6;}

/* ============ FOOTER ============ */
.footer{padding:64px 0 40px; border-top:1px solid var(--line);}
.foot-top{display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:32px; padding-bottom:40px;}
.foot-brand .logo{margin-bottom:14px;}
.foot-brand p{color:var(--ink-500); font-size:15px; max-width:34ch;}
.foot-col h5{font-size:14px; font-weight:700; letter-spacing:.04em; margin-bottom:14px; color:var(--ink-900);}
.foot-col a{display:block; color:var(--ink-500); font-size:14.5px; padding:5px 0; transition:color .15s var(--ease);}
.foot-col a:hover{color:var(--amber-700);}
.foot-bot{border-top:1px solid var(--line); padding-top:24px; display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; color:var(--ink-500); font-size:14px;}

/* ============ TOAST ============ */
.toast{
  position:fixed; bottom:26px; inset-inline-start:50%; transform:translateX(-50%) translateY(24px);
  background:var(--ink-900); color:var(--sand-50); padding:14px 22px; border-radius:999px;
  font-size:15px; font-weight:600; box-shadow:var(--shadow-lg); z-index:200;
  opacity:0; pointer-events:none; transition:opacity .25s var(--ease), transform .25s var(--ease);
  display:flex; align-items:center; gap:10px; max-width:90vw;
}
.toast.show{opacity:1; transform:translateX(-50%) translateY(0);}
.toast svg{width:20px; height:20px; stroke:var(--mustard); fill:none; stroke-width:2.2; flex:none;}

/* ============ MOBILE MENU ============ */
.mmenu{position:fixed; inset:0; z-index:90; background:var(--sand-50); transform:translateX(100%); transition:transform .32s var(--ease); display:flex; flex-direction:column; padding:20px;}
.mmenu.open{transform:none;}
.mmenu-top{display:flex; align-items:center; justify-content:space-between; height:54px;}
.mmenu-close{width:44px; height:44px; border-radius:12px; border:1.5px solid var(--line); background:var(--cream); display:grid; place-items:center;}
.mmenu-close svg{width:22px; height:22px; stroke:var(--ink-900); stroke-width:2;}
.mmenu nav{display:flex; flex-direction:column; gap:6px; margin-top:30px;}
.mmenu nav a{font-family:var(--serif); font-weight:700; font-size:26px; padding:12px 4px; color:var(--ink-900);}
.mmenu .btn-amber{margin-top:auto; text-align:center;}

/* ============ STICKY MINI-SEARCH ============ */
.ministick{
  position:fixed; top:74px; inset-inline:0; z-index:55;
  display:flex; justify-content:center; padding:10px 18px;
  opacity:0; visibility:hidden; transform:translateY(-14px);
  transition:opacity .3s var(--ease), transform .32s var(--ease), visibility .3s var(--ease);
  pointer-events:none;
}
.ministick.show{opacity:1; visibility:visible; transform:none; pointer-events:auto;}
.mini-search{
  display:flex; align-items:center; gap:0; width:100%; max-width:560px;
  background:var(--cream); border:1px solid var(--line); border-radius:999px;
  box-shadow:var(--shadow-md); padding:6px; transition:box-shadow .2s var(--ease), transform .2s var(--ease);
}
.mini-search:hover{box-shadow:var(--shadow-lg); transform:translateY(-1px);}
.mini-search .mf{flex:1; display:flex; flex-direction:column; align-items:flex-start; padding:4px 18px; min-width:0;}
.mini-search .mf + .mf{border-inline-start:1px solid var(--line);}
.mini-search .mlab{font-size:11px; font-weight:700; color:var(--amber-800); letter-spacing:.02em;}
.mini-search .mval{font-size:14px; font-weight:600; color:var(--ink-900); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:100%;}
.mini-search .mf.muted .mlab{color:var(--ink-500);}
.mini-search .mf.muted .mval{color:var(--ink-500); font-weight:500;}
.mini-go{flex:none; width:46px; height:46px; border-radius:50%; background:var(--amber-600); color:#3a2a08; border:none; display:grid; place-items:center; transition:all .18s var(--ease);}
.mini-go:hover{background:var(--amber-700);}
.mini-go:hover svg{transform:rotate(-12deg);}
.mini-go svg{width:20px; height:20px; stroke:currentColor; fill:none; stroke-width:2.4; stroke-linecap:round; stroke-linejoin:round; transition:transform .35s var(--ease);}

/* ============ REVIEWS ============ */
.reviews{background:var(--amber-50); border-top:1px solid var(--line-soft); border-bottom:1px solid var(--line-soft);}
.review-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:22px;}
.rcard{background:var(--cream); border:1px solid var(--line-soft); border-radius:var(--r-lg); padding:26px 24px; box-shadow:var(--shadow-xs); transition:transform .25s var(--ease), box-shadow .25s var(--ease); display:flex; flex-direction:column; gap:14px;}
.rcard:hover{transform:translateY(-5px); box-shadow:var(--shadow-md);}
.rcard .stars{color:var(--mustard); font-size:16px; letter-spacing:2px;}
.rcard blockquote{font-family:var(--serif); font-weight:500; font-size:18.5px; line-height:1.5; color:var(--ink-900); flex:1;}
.rcard figcaption{display:flex; align-items:center; gap:13px; margin-top:2px;}
.rcard .rav{width:50px; height:50px; flex:none; display:block; border-radius:50%; box-shadow:0 2px 6px rgba(60,42,24,.14);}
.rcard .rn{display:block; font-weight:700; font-size:15.5px; color:var(--ink-900);}
.rcard .rm{display:block; font-size:13px; color:var(--ink-500);}

/* ============ OWNER STRIP ============ */
.ownerstrip{padding:14px 0 56px;}
.owner-inner{
  background:linear-gradient(135deg,var(--amber-100),var(--amber-50));
  border:1px solid var(--amber-300); border-radius:var(--r-2xl);
  padding:clamp(28px,4vw,44px) clamp(26px,4vw,52px);
  display:flex; align-items:center; justify-content:space-between; gap:28px; flex-wrap:wrap;
  position:relative; overflow:hidden;
}
.owner-inner::before{content:""; position:absolute; inset-inline-start:-60px; bottom:-90px; width:240px; height:240px; border-radius:50%; background:rgba(244,198,54,.28);}
.owner-copy{position:relative; z-index:1; max-width:60ch;}
.owner-copy h3{font-size:clamp(22px,3vw,30px); font-weight:800; color:var(--ink-900); line-height:1.15;}
.owner-copy p{margin-top:8px; font-size:16px; color:var(--ink-700);}
.owner-btn{position:relative; z-index:1; flex:none;}

/* ============ RESPONSIVE ============ */
@media(min-width:981px){
  .hero-grid{grid-template-columns:1.05fr .95fr;}
}
@media(max-width:980px){
  .nav{display:none;}
  .hdr-actions .btn-ghost{display:none;}
  .hamburger{display:flex;}
  .hero-grid{grid-template-columns:1fr;}
  .hero-photo{order:-1;}
  .hero-photo .floatchip{inset-inline-start:auto; inset-inline-end:14px;}
  .tiles{grid-template-columns:repeat(3,1fr);}
  .promise-grid{grid-template-columns:repeat(2,1fr);}
  .grid-cards{grid-template-columns:repeat(2,1fr);}
  .review-grid{grid-template-columns:1fr 1fr;}
  .foot-top{grid-template-columns:1fr 1fr;}
}
@media(max-width:640px){
  .hero{padding:30px 0 10px;}
  .searchbar{flex-direction:row; align-items:stretch; border-radius:999px; padding:5px; gap:0;}
  .sfield{border-radius:999px; padding:9px 7px; align-items:center; text-align:center;}
  .sfield .lab{font-size:10.5px;}
  .sfield .val{font-size:11.5px;}
  .sfield.celebrate{flex:1;}
  .sfield + .sfield::before{display:none;}
  .sfield + .sfield{border-inline-start:1px solid var(--line);}
  .search-go{width:46px; height:auto; margin:0; margin-inline-start:3px; border-radius:999px;}
  .search-go::after{content:none;}
  .searchwrap .sfield.where, .searchwrap .sfield.when{position:static;}
  .searchwrap .sfield.where .dropdown, .searchwrap .sfield.when .dropdown{left:0; right:0; inset-inline-start:0; inset-inline-end:0; width:auto;}
  .bubble{top:-22px;}
  .dropdown{width:calc(100vw - 36px);}
  .tiles{grid-template-columns:repeat(2,1fr); gap:12px;}
  .tile{aspect-ratio:4/5;}
  .promise-grid{grid-template-columns:1fr 1fr;}
  .grid-cards{grid-template-columns:1fr;}
  .review-grid{grid-template-columns:1fr;}
  .steps{flex-direction:column; align-items:center; gap:42px;}
  .step{max-width:340px;}
  .step:not(:last-child)::after{top:auto; bottom:-42px; inset-inline-end:auto; left:50%; transform:translateX(-50%) rotate(90deg); width:42px;}
  .ministick .mf:nth-child(2){display:none;}
  .owner-inner{flex-direction:column; align-items:flex-start;}
  .foot-top{grid-template-columns:1fr 1fr;}
  .sec-head{margin-bottom:20px;}
}

/* ============ LOGIN-REQUIRED POPUP (favorites) ============ */
.login-pop{
  position:fixed; bottom:24px; inset-inline-start:24px; z-index:220;
  width:340px; max-width:calc(100vw - 36px);
  background:var(--cream); border:1px solid var(--line); border-radius:var(--r-lg);
  box-shadow:var(--shadow-lg); padding:16px; display:flex; gap:13px;
  opacity:0; transform:translateY(20px) scale(.96); pointer-events:none;
  transition:opacity .32s var(--ease), transform .32s var(--ease);
}
.login-pop.show{opacity:1; transform:none; pointer-events:auto;}
.login-pop .lp-ic{flex:none; width:44px; height:44px; border-radius:14px; background:var(--amber-100); display:grid; place-items:center;}
.login-pop .lp-ic svg{width:23px; height:23px; stroke:var(--amber-800); fill:none; stroke-width:1.9; stroke-linecap:round; stroke-linejoin:round;}
.login-pop .lp-text{flex:1; min-width:0;}
.login-pop .lp-text p{font-size:14px; color:var(--ink-700); line-height:1.5;}
.login-pop .lp-act{margin-top:11px; background:var(--ink-900); color:var(--sand-50); border:none; border-radius:999px; padding:9px 18px; font-family:var(--sans); font-weight:700; font-size:13.5px; cursor:pointer; transition:background .15s var(--ease);}
.login-pop .lp-act:hover{background:var(--amber-600); color:#3a2a08;}
.login-pop .lp-close{position:absolute; top:10px; inset-inline-end:10px; width:24px; height:24px; border-radius:50%; border:none; background:transparent; color:var(--ink-300); display:grid; place-items:center; cursor:pointer;}
.login-pop .lp-close:hover{background:var(--sand-100); color:var(--ink-700);}
.login-pop .lp-close svg{width:13px; height:13px; stroke:currentColor; stroke-width:2.4; fill:none; stroke-linecap:round;}
@media(max-width:640px){ .login-pop{inset-inline:12px; width:auto; bottom:16px;} }
