/* ════════════════════════════════════════════════════════════════
   HALA PLANNER — shared surface styles for /trips.html (home) and
   /trip.html (a single trip). House style: cream #F4EFE6, terracotta
   #B25238, Fraunces / Schibsted / IBM Plex Mono, grain, languid motion.
   Member-gated utility surface (its own route — not a modal). Powered by
   planner.js + trip-store.js. Styles grow with each build increment;
   increment 2 covers chrome, gate, home list, and the trip shell.
   ════════════════════════════════════════════════════════════════ */
:root{
  --cream:#F5E9D5;--cream-soft:#EFE0C6;--cream-deep:#E8D5B5;
  --espresso:#1F1A14;--ink-60:rgba(31,26,20,.62);--ink-38:rgba(31,26,20,.40);
  --terra:#B25238;--terra-deep:#8E3F2A;--ochre:#C98A3A;
  --hair:rgba(31,26,20,.12);--hair-soft:rgba(31,26,20,.08);
  --fd:"Fraunces",ui-serif,Georgia,serif;
  --fb:"Schibsted Grotesk","Hanken Grotesk",ui-sans-serif,system-ui,sans-serif;
  --fu:"Space Mono",ui-monospace,Menlo,monospace;
  --wm:'EB Garamond','Hoefler Text',Garamond,serif;
  --max:1100px;--g:clamp(18px,4vw,52px);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--fb);background:var(--cream);color:var(--espresso);-webkit-font-smoothing:antialiased;overflow-x:hidden;position:relative}
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.045;mix-blend-mode:multiply;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='1.4' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.16 0 0 0 0 0.10 0 0 0 0 0.06 0 0 0 0.65 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>")}
img{max-width:100%;display:block}a{color:inherit}

/* ── nav (matches account.html) ─────────────────────────────── */
.hala-nav{background:var(--cream-soft);border-bottom:.5px solid var(--hair);position:sticky;top:0;z-index:200}
.hala-nav__inner{max-width:var(--max);margin:0 auto;padding:0 var(--g);height:62px;display:flex;align-items:center;justify-content:space-between}
.hala-nav__wordmark{font-family:var(--wm)!important;font-size:21px!important;letter-spacing:.16em!important;text-transform:uppercase!important;color:var(--espresso);text-decoration:none}
.hala-nav__links{display:flex;align-items:center;gap:1.8rem;list-style:none}
.hala-nav__links a,.hala-nav__links button.hw-navlink{font-family:var(--fb);font-size:13px;letter-spacing:.04em;color:var(--espresso);opacity:.7;text-decoration:none;background:none;border:none;cursor:pointer;transition:opacity .2s,color .2s}
.hala-nav__links a:hover{opacity:1;color:var(--terra)}
.hala-nav__toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.hala-nav__toggle span{display:block;width:22px;height:1px;background:var(--espresso)}
@media(max-width:780px){
  .hala-nav__links{display:none;position:absolute;top:62px;left:0;right:0;flex-direction:column;align-items:flex-start;gap:0;background:var(--cream-soft);border-bottom:.5px solid var(--hair);padding:6px var(--g) 14px;box-shadow:0 16px 30px rgba(31,26,20,.08);z-index:199}
  .hala-nav__links.open{display:flex}
  .hala-nav__links li{width:100%}
  .hala-nav__links a,.hala-nav__links button.hw-navlink{display:block;width:100%;padding:12px 0;font-size:15px;opacity:.85;border-bottom:1px solid var(--hair-soft)}
  .hala-nav__toggle{display:flex}
}

.pl-wrap{max-width:var(--max);margin:0 auto;padding:0 var(--g)}
.pl-mono{font-family:var(--fu);font-size:9.5px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--terra)}
.pl-state{display:none}

/* ── gate ───────────────────────────────────────────────────── */
.pl-gate{max-width:var(--max);margin:0 auto;padding:clamp(60px,11vw,140px) var(--g);text-align:center}
.pl-gate h1{font-family:var(--fd);font-weight:400;font-size:clamp(26px,3.4vw,40px);color:var(--espresso);margin-bottom:13px}
.pl-gate p{font-family:var(--fb);font-size:15.5px;color:var(--ink-60);max-width:44ch;margin:0 auto 22px;line-height:1.6}

/* ── buttons ────────────────────────────────────────────────── */
.pl-btn{font-family:var(--fb);font-size:13px;padding:11px 22px;border-radius:2px;text-decoration:none;cursor:pointer;border:1px solid var(--terra);background:var(--terra);color:var(--cream);white-space:nowrap;transition:background .25s ease,border-color .25s ease,transform .2s ease}
.pl-btn:hover{background:var(--terra-deep);border-color:var(--terra-deep);transform:translateY(-1px)}
.pl-btn.ghost{background:transparent;color:var(--espresso);border-color:var(--hair)}
.pl-btn.ghost:hover{border-color:var(--terra);color:var(--terra);background:transparent;transform:none}
.pl-link{font-family:var(--fu);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--terra);text-decoration:none;background:none;border:none;cursor:pointer}

/* ── home: header + folders + trip cards ────────────────────── */
.pl-head{padding:clamp(32px,4.5vw,52px) 0 clamp(14px,2vw,22px)}
.pl-head .row{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;flex-wrap:wrap}
.pl-head .k{display:block;margin-bottom:12px}
.pl-head h1{font-family:var(--fd);font-weight:400;font-size:clamp(26px,3vw,38px);line-height:1.04;letter-spacing:-.01em;color:var(--espresso)}
.pl-head .sub{font-family:var(--fd);font-style:italic;font-size:clamp(14.5px,1.3vw,16.5px);color:var(--terra-deep);margin-top:9px;max-width:52ch;line-height:1.4}

.pl-folder{padding:clamp(20px,3vw,32px) 0;border-top:1px solid var(--hair)}
.pl-folder-head{display:flex;align-items:baseline;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:16px}
.pl-folder-acts{display:flex;gap:14px;flex-shrink:0}
.pl-folder-name{font-family:var(--fu);font-size:10px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-38)}
.pl-head-actions{display:flex;gap:10px;flex-wrap:wrap}
.pl-trip-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:clamp(12px,1.6vw,18px)}
.pl-tripcard{display:block;text-decoration:none;border:1px solid var(--hair);border-radius:5px;background:var(--cream-soft);padding:clamp(18px,2.2vw,26px);transition:border-color .2s ease,transform .25s cubic-bezier(.2,.65,.3,1),box-shadow .25s ease}
.pl-tripcard:hover{border-color:var(--terra);transform:translateY(-2px);box-shadow:0 12px 30px rgba(31,26,20,.08)}
.pl-tripcard-title{font-family:var(--fd);font-size:clamp(19px,2vw,24px);color:var(--espresso);line-height:1.1;margin-bottom:8px}
.pl-tripcard-shape{font-family:var(--fb);font-size:13.5px;color:var(--ink-60);line-height:1.45}
.pl-tripcard-meta{font-family:var(--fu);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-38);margin-top:12px}
.pl-tripcard.new{background:transparent;border-style:dashed;display:flex;align-items:center;justify-content:center;min-height:120px;color:var(--terra);font-family:var(--fd);font-style:italic;font-size:18px}
.pl-tripcard.new:hover{transform:translateY(-2px);box-shadow:none}

/* ── empty states ───────────────────────────────────────────── */
.pl-empty{border:1px dashed var(--hair);border-radius:5px;padding:clamp(24px,3.5vw,40px);text-align:center;background:rgba(255,255,255,.22)}
.pl-empty p{font-family:var(--fd);font-style:italic;font-size:clamp(15px,1.6vw,18px);color:var(--ink-60);max-width:52ch;margin:0 auto 14px;line-height:1.5}

/* ── trip surface: header / back / shape / body ─────────────── */
.pl-back{display:inline-flex;align-items:center;gap:7px;font-family:var(--fu);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-60);text-decoration:none;padding:clamp(20px,3vw,30px) 0 0;transition:color .2s ease}
.pl-back:hover{color:var(--terra)}
.pl-trip-head{padding:clamp(10px,1.6vw,18px) 0 clamp(16px,2.2vw,26px);border-bottom:1px solid var(--hair)}
.pl-trip-head .row{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;flex-wrap:wrap}
.pl-trip-head h1{font-family:var(--fd);font-weight:400;font-size:clamp(28px,3.6vw,46px);line-height:1.02;letter-spacing:-.015em;color:var(--espresso)}
.pl-trip-head h1[contenteditable]{outline:none;border-bottom:1px dashed transparent;transition:border-color .2s ease}
.pl-trip-head h1[contenteditable]:hover,.pl-trip-head h1[contenteditable]:focus{border-bottom-color:var(--hair)}
.pl-trip-shape{font-family:var(--fd);font-style:italic;font-size:clamp(15px,1.5vw,19px);color:var(--terra-deep);margin-top:10px}
.pl-trip-actions{display:flex;gap:10px;flex-shrink:0;align-items:center}
.pl-trip-body{padding:clamp(20px,3vw,34px) 0 clamp(40px,6vw,72px)}

/* ── trip glance (live totals) + multi-leg overview ─────────── */
.pl-glance{display:flex;flex-wrap:wrap;gap:clamp(14px,2.4vw,30px);padding:clamp(15px,2vw,22px) clamp(16px,2.2vw,24px);border:1px solid var(--hair);border-radius:6px;background:var(--cream-soft);margin-bottom:clamp(16px,2.2vw,24px)}
.pl-stat{display:flex;flex-direction:column;gap:4px;min-width:64px}
.pl-stat .v{font-family:var(--fd);font-size:clamp(20px,2.2vw,27px);color:var(--espresso);line-height:1}
.pl-stat .v.warn{color:var(--terra)}
.pl-stat .l{font-family:var(--fu);font-size:8.5px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-38)}
.pl-overview{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:clamp(18px,2.6vw,28px)}
.pl-ov-leg{display:flex;flex-direction:column;gap:2px;background:none;border:1px solid var(--hair);border-radius:4px;padding:8px 13px;cursor:pointer;text-align:left;transition:border-color .2s ease,transform .15s ease}
.pl-ov-leg:hover{border-color:var(--terra);transform:translateY(-1px)}
.pl-ov-leg .r{font-family:var(--fd);font-size:15px;color:var(--espresso);line-height:1.1}
.pl-ov-leg .m{font-family:var(--fu);font-size:8px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-38)}
.pl-ov-arr{color:var(--ink-38);font-size:13px}
.pl-day-meta{font-family:var(--fu);font-size:8px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-38);margin:-4px 0 1px}
.pl-day-meta.busy{color:var(--terra)}

/* ── Hala notices (rule-based intelligence) ─────────────────── */
.pl-notices{border:1px solid var(--ochre);border-radius:6px;background:rgba(201,138,58,.05);padding:clamp(15px,2vw,22px) clamp(16px,2.2vw,24px);margin-bottom:clamp(18px,2.6vw,28px)}
.pl-notices-head{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.pl-notices-head .k{font-family:var(--fu);font-size:9.5px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--terra)}
.pl-notices-head .c{font-family:var(--fu);font-size:9px;color:var(--cream);background:var(--terra);border-radius:10px;padding:1px 7px;line-height:1.5}
.pl-notice{display:flex;gap:13px;align-items:baseline;padding:9px 0;border-top:1px solid var(--hair-soft)}
.pl-notice:first-of-type{border-top:none}
.pl-notice .nk{flex:0 0 74px;font-family:var(--fu);font-size:8px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-38);padding-top:3px}
.pl-notice p{font-family:var(--fd);font-size:clamp(14.5px,1.5vw,16.5px);line-height:1.5;color:var(--espresso)}
.pl-notice.calm p{font-style:italic;color:var(--ink-60)}
@media(max-width:520px){.pl-notice{flex-direction:column;gap:2px}.pl-notice .nk{flex:none;padding-top:0}}

/* ── legs ───────────────────────────────────────────────────── */
.pl-leg{padding:clamp(18px,2.6vw,28px) 0;border-top:1px solid var(--hair)}
.pl-leg:first-child{border-top:none}
.pl-leg-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:16px}
.pl-leg-head .pl-mono{display:block;margin-bottom:6px;text-transform:capitalize}
.pl-leg-head h2{font-family:var(--fd);font-weight:400;font-size:clamp(21px,2.4vw,30px);line-height:1.04;color:var(--espresso)}
.pl-leg-dates{font-family:var(--fb);font-size:13px;color:var(--ink-60);margin-top:7px}
.pl-leg-acts{display:flex;gap:14px;flex-shrink:0;align-items:center}

/* day columns — horizontal scroll on desktop, stack on mobile */
.pl-days{display:flex;gap:clamp(10px,1.2vw,16px);overflow-x:auto;padding-bottom:6px;scroll-snap-type:x proximity}
.pl-day{flex:0 0 clamp(220px,22vw,260px);scroll-snap-align:start;display:flex;flex-direction:column;gap:9px}
.pl-day-date{font-family:var(--fu);font-size:9.5px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--terra);padding:2px 0 4px;border-bottom:1px solid var(--hair-soft);display:flex;align-items:center;justify-content:space-between;gap:8px}
.pl-day-copy{background:none;border:none;cursor:pointer;font-family:var(--fu);font-size:8px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-38);padding:0;flex-shrink:0}
.pl-day-copy:hover{color:var(--terra)}
.pl-item{cursor:grab}
.pl-item.dragging{opacity:.4}
.pl-slot.drop-hover{border-style:solid;border-color:var(--terra);background:rgba(178,82,56,.07)}
.pl-slot{border:1px dashed var(--hair);border-radius:4px;background:rgba(255,255,255,.22);padding:10px 12px;min-height:62px;display:flex;flex-direction:column;gap:7px;transition:border-color .2s ease,background .2s ease}
.pl-slot-label{font-family:var(--fu);font-size:8.5px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-38);display:flex;justify-content:space-between;gap:8px}
.pl-slot-time{color:var(--ink-38);opacity:.8}
.pl-departure{margin-top:14px;font-family:var(--fu);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-38);padding:9px 12px;border:1px solid var(--hair-soft);border-radius:4px;background:transparent;display:inline-block}
@media(max-width:640px){.pl-days{flex-direction:column;overflow-x:visible}.pl-day{flex:none}}

/* slot with items: the unsorted bucket reads a touch warmer */
.pl-slot.has{border-style:solid;border-color:var(--hair);background:rgba(255,255,255,.4)}
.pl-slot.unsorted{border-color:var(--ochre);background:rgba(201,138,58,.06)}
.pl-slot.stay{border-style:solid;border-color:rgba(178,82,56,.35);background:rgba(178,82,56,.045)}
.pl-slot.stay .pl-slot-label{color:var(--terra)}
/* item chip */
.pl-item{display:flex;align-items:flex-start;gap:8px;background:var(--cream-soft);border:1px solid var(--hair);border-radius:3px;padding:8px 9px;position:relative}
.pl-item-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.pl-item-type{font-family:var(--fu);font-size:8px;font-weight:500;letter-spacing:.13em;text-transform:uppercase;color:var(--terra)}
.pl-item-name{font-family:var(--fd);font-size:14px;line-height:1.2;color:var(--espresso)}
.pl-item-sub{font-family:var(--fu);font-size:8.5px;letter-spacing:.06em;color:var(--ink-38);display:flex;gap:7px;flex-wrap:wrap;margin-top:1px}
.pl-mark{font-family:var(--fu);font-size:8.5px;font-weight:600;color:var(--terra)}
.pl-mark.pick{color:var(--ochre)}
.pl-item-rm{flex-shrink:0;background:none;border:none;cursor:pointer;color:var(--ink-38);font-size:16px;line-height:1;padding:0 2px;transition:color .2s ease}
.pl-item-rm:hover{color:var(--terra)}
.pl-slot-add{margin-top:2px;align-self:flex-start;background:none;border:none;cursor:pointer;font-family:var(--fu);font-size:8.5px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-38);padding:3px 0;transition:color .2s ease}
.pl-slot-add:hover{color:var(--terra)}

/* ── add-place picker overlay ───────────────────────────────── */
.pl-picker-back{position:fixed;inset:0;z-index:10000;display:flex;align-items:flex-end;justify-content:center;background:rgba(31,26,20,.42);backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);opacity:0;transition:opacity .28s ease}
.pl-picker-back.on{opacity:1}
.pl-picker{width:100%;max-width:560px;max-height:84vh;display:flex;flex-direction:column;background:var(--cream);border:1px solid var(--terra);border-bottom:none;border-radius:8px 8px 0 0;box-shadow:0 -20px 60px rgba(31,26,20,.28);transform:translateY(24px);transition:transform .34s cubic-bezier(.2,.65,.3,1)}
.pl-picker-back.on .pl-picker{transform:none}
@media(min-width:640px){.pl-picker-back{align-items:center}.pl-picker{border-bottom:1px solid var(--terra);border-radius:8px;transform:translateY(16px)}}
.pl-picker-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:clamp(18px,2.4vw,24px) clamp(18px,2.4vw,24px) 12px}
.pl-picker-head .k{font-family:var(--fu);font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--terra);display:block;margin-bottom:5px}
.pl-picker-head h3{font-family:var(--fd);font-weight:400;font-size:clamp(18px,2vw,23px);color:var(--espresso);line-height:1.1}
.pl-picker-close{background:none;border:none;font-size:22px;line-height:1;color:var(--ink-38);cursor:pointer;padding:0 2px}
.pl-picker-close:hover{color:var(--terra)}
.pl-picker-tabs{display:flex;gap:18px;padding:0 clamp(18px,2.4vw,24px)}
.pl-picker-tab{background:none;border:none;cursor:pointer;font-family:var(--fu);font-size:10px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-38);padding:6px 0;border-bottom:2px solid transparent;transition:color .2s ease,border-color .2s ease}
.pl-picker-tab.on{color:var(--terra);border-bottom-color:var(--terra)}
.pl-picker-controls{display:flex;gap:10px;align-items:center;padding:12px clamp(18px,2.4vw,24px);flex-wrap:wrap}
.pl-picker-search{flex:1;min-width:160px;font-family:var(--fb);font-size:14px;color:var(--espresso);background:rgba(255,255,255,.6);border:1px solid var(--hair);border-radius:3px;padding:9px 11px;outline:none}
.pl-picker-search:focus{border-color:var(--terra)}
.pl-picker-types{display:flex;gap:6px}
.pl-tf{background:none;border:1px solid var(--hair);border-radius:2px;cursor:pointer;font-family:var(--fu);font-size:8.5px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-60);padding:6px 9px;transition:all .2s ease}
.pl-tf.on{background:var(--terra);border-color:var(--terra);color:var(--cream)}
.pl-picker-list{overflow-y:auto;padding:4px clamp(18px,2.4vw,24px) clamp(18px,2.4vw,24px);display:flex;flex-direction:column;gap:7px}
.pl-pick-row{display:flex;align-items:center;gap:11px;border:1px solid var(--hair);border-radius:4px;background:var(--cream-soft);padding:8px 10px;cursor:pointer;text-align:left;transition:border-color .2s ease,transform .15s ease}
.pl-pick-row:hover{border-color:var(--terra);transform:translateX(2px)}
.pl-pick-row.added{opacity:.55;cursor:default}
.pl-pick-row.added:hover{border-color:var(--hair);transform:none}
.pl-pick-thumb{width:46px;height:46px;border-radius:3px;object-fit:cover;background:var(--cream-deep);flex-shrink:0}
.pl-pick-body{flex:1;min-width:0}
.pl-pick-name{font-family:var(--fd);font-size:15px;color:var(--espresso);line-height:1.15}
.pl-pick-meta{font-family:var(--fu);font-size:8.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-38);margin-top:3px;display:flex;gap:8px;flex-wrap:wrap}
.pl-pick-add{flex-shrink:0;font-family:var(--fu);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--terra)}
.pl-pick-empty{font-family:var(--fd);font-style:italic;font-size:15px;color:var(--ink-60);padding:24px 4px;line-height:1.5}

.pl-addleg{margin-top:clamp(20px,3vw,30px)}
.pl-foot-note{margin-top:18px;font-family:var(--fd);font-style:italic;font-size:14px;color:var(--ink-38)}
.pl-empty.small{padding:clamp(16px,2vw,22px)}
.pl-empty.small p{font-size:14.5px;margin-bottom:0}

/* ── leg builder modal: date row ────────────────────────────── */
.pl-date-row{display:flex;gap:12px;margin-top:14px}
.pl-date-row>div{flex:1}
@media(max-width:420px){.pl-date-row{flex-direction:column;gap:10px}}

/* ── footer (matches account.html) ──────────────────────────── */
.hala-footer{background:var(--cream-soft);border-top:.5px solid var(--hair);margin-top:40px}
.hala-footer__inner{max-width:var(--max);margin:0 auto;padding:3.5rem var(--g) 2.5rem;display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:2rem;align-items:start}
.hala-footer__wordmark{font-family:var(--wm);font-size:20px;font-weight:400;color:var(--espresso);letter-spacing:.08em;display:block;margin-bottom:.75rem;text-decoration:none;transition:letter-spacing .3s ease,color .2s ease}
.hala-footer__wordmark:hover{letter-spacing:.18em;color:var(--terra)}
.hala-footer__tagline{font-family:var(--fd);font-size:14px;font-style:italic;color:var(--ink-60);line-height:1.6;max-width:220px}
.hala-footer__col-label{font-family:var(--fu);font-size:9px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-38);margin-bottom:1rem;display:block}
.hala-footer__links{list-style:none;display:flex;flex-direction:column;gap:.65rem}
.hala-footer__links a{font-family:var(--fb);font-size:14px;color:var(--ink-60);text-decoration:none;transition:color .2s ease}
.hala-footer__links a:hover{color:var(--terra)}
.hala-footer__bottom{max-width:var(--max);margin:0 auto;padding:1.25rem var(--g);border-top:.5px solid var(--hair);display:flex;align-items:center;justify-content:space-between;gap:1rem}
.hala-footer__copy{font-family:var(--fu);font-size:11px;color:var(--ink-38);letter-spacing:.04em}
.hala-footer__social a{font-family:var(--fu);font-size:11px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-38);text-decoration:none;transition:color .2s ease}
.hala-footer__social a:hover{color:var(--terra)}
@media(max-width:680px){.hala-footer__inner{grid-template-columns:1fr;gap:1.6rem}.hala-footer__bottom{flex-direction:column;align-items:flex-start;gap:.75rem}}

/* ── shared (read-only) view ────────────────────────────────── */
.pl-shared-banner{border:1px solid var(--ochre);background:rgba(201,138,58,.06);border-radius:5px;padding:12px 16px;margin-bottom:22px;font-family:var(--fb);font-size:13.5px;color:var(--ink-60)}
.pl-shared-banner a{color:var(--terra);text-decoration:none}
.pl-shared-tag{font-family:var(--fu);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-38);align-self:center}

/* ── print / PDF ────────────────────────────────────────────── */
@media print{
  .hala-nav,.hala-footer,.hw-fab,.hu-toast,.hu-backdrop,.pl-trip-actions,.pl-addleg,.pl-slot-add,.pl-day-copy,.pl-item-rm,.pl-back,.pl-notices,.pl-overview{display:none!important}
  body::before{display:none!important}
  body{background:#fff}
  .pl-days{flex-direction:row;flex-wrap:wrap;overflow:visible}
  .pl-day{flex:1 1 30%;break-inside:avoid;min-width:0}
  .pl-slot{min-height:auto;border-style:solid}
  .pl-glance,.pl-leg{break-inside:avoid}
}

/* ── motion ─────────────────────────────────────────────────── */
.fade-in{opacity:0;animation:pl-rise .7s ease forwards}
@keyframes pl-rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.fade-in{opacity:1!important;transform:none!important}}

/* ── TYPE v2 — Syne display headline + Schibsted data (functional restraint; Syne never on data/figures) ── */
.pl-gate h1,.pl-head h1,.pl-trip-head h1{font-family:'Syne',ui-sans-serif,sans-serif;font-weight:700;font-style:normal;letter-spacing:-.02em;font-variation-settings:normal}
.pl-leg-head h2,.pl-picker-head h3{font-family:var(--fb);font-weight:600;letter-spacing:-.005em}
.pl-tripcard-title,.pl-stat .v,.pl-ov-leg .r,.pl-notice p,.pl-item-name,.pl-pick-name{font-family:var(--fb);font-weight:500}
