/* Puschels.ch — public site styles, ported 1:1 from the Claude design prototype.
   Pink accent is the default. Prototype-only chrome (device frame, accent
   switcher) and the Norsk easter egg are intentionally omitted. */

:root{
  --bg:#fbf6f0; --surface:#ffffff; --ink:#2b2521; --ink2:#74695f; --ink3:#9c9085;
  --line:#efe7dc; --line2:#e3d9cc;
  --coral:#e8638f; --coral-600:#d24e7c; --coral-100:#fbdfeb; --coral-50:#fcecf3;
  --red:#e23b2e; --green:#3fa06a; --amber:#e0a13a; --blue:#5b86c4; --blue-50:#eaf0f9;
  --de:#d99a3c; --fr:#7a6fc0; --br:#2f8f86; --se:#5b86c4;
  --r:16px; --r-lg:22px; --r-sm:11px;
  --f:'Nunito',system-ui,sans-serif;
}

*{ box-sizing:border-box; }
body{ margin:0; background:var(--bg); color:var(--ink); font-family:var(--f); font-size:16px; line-height:1.45; -webkit-font-smoothing:antialiased; }
button{ font-family:inherit; cursor:pointer; }
a{ color:inherit; }
.paw{ flex:none; vertical-align:middle; fill:var(--ink); }
.paw.wm{ fill:var(--coral); opacity:.5; }
.paw.ico{ width:1.05em; height:1.05em; }
.ic{ flex:none; vertical-align:middle; }

/* ---------- header ---------- */
.ph{ position:sticky; top:0; z-index:30; display:flex; align-items:center; gap:18px; padding:13px 26px;
  background:rgba(255,255,255,.92); backdrop-filter:blur(8px); border-bottom:1px solid var(--line); }
.brand{ display:flex; align-items:center; gap:8px; border:0; background:transparent; padding:0; text-decoration:none; color:inherit; }
.brand .paw{ fill:var(--coral); }
.brand b{ font-size:20px; font-weight:800; letter-spacing:-.02em; }
.brand b span{ color:var(--coral); }
.pnav{ display:flex; gap:4px; }
.pnav a{ border:0; background:transparent; padding:7px 12px; border-radius:999px; font-weight:700; font-size:14.5px; color:var(--ink2); white-space:nowrap; text-decoration:none; }
.pnav a:hover{ background:var(--coral-50); color:var(--ink); }
.pnav a.on{ color:var(--coral); }
.ph-r{ margin-left:auto; display:flex; align-items:center; gap:10px; }
.lang{ display:inline-flex; background:#fff; border:1.5px solid var(--line2); border-radius:999px; padding:2px; }
.lang button, .lang a{ border:0; background:transparent; border-radius:999px; padding:3px 8px; font-size:11.5px; font-weight:800; color:var(--ink3); text-decoration:none; }
.lang button.on, .lang a.on{ background:var(--coral); color:#fff; }
.iconbtn{ display:inline-flex; align-items:center; justify-content:center; width:40px; height:40px; border-radius:50%; border:1.5px solid var(--line2); background:#fff; color:var(--ink); }
.only-m{ display:none; }
.ph-menu{ display:none; }

/* ---------- buttons ---------- */
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:7px; border:1.6px solid transparent;
  border-radius:999px; padding:10px 18px; font-weight:800; font-size:15px; color:var(--ink); background:#fff; white-space:nowrap; line-height:1; text-decoration:none; }
.btn .paw{ fill:currentColor; }
.btn.primary{ background:var(--coral); color:#fff; }
.btn.primary:hover{ background:var(--coral-600); }
.btn.ghost{ background:transparent; border-color:var(--line2); color:var(--ink); }
.btn.ghost:hover{ background:#fff; border-color:var(--ink3); }
.btn.sm{ padding:8px 14px; font-size:13.5px; }
.btn.block{ width:100%; padding:13px; font-size:16px; }

/* ---------- badges ---------- */
.bg{ display:inline-flex; align-items:center; gap:4px; font-size:12px; font-weight:800; border-radius:999px;
  padding:3px 10px; background:#f1ece4; color:var(--ink2); line-height:1.5; white-space:nowrap; }
.bg .paw,.bg .ic{ width:13px; height:13px; }
.bg.ch{ background:var(--red); color:#fff; }
.bg.de{ background:#fbeccf; color:#7a5410; } .bg.se,.bg.blue{ background:#dde7f5; color:#2f4f80; }
.bg.fr{ background:#e7e2f6; color:#4a3f8a; } .bg.br{ background:#cfeee9; color:#1f6b63; }
.bg.us{ background:#dde7f5; color:#2f4f80; }
.bg.age{ background:#fbeccf; color:#8a5e12; }
.bg.soft{ background:#f1ece4; color:var(--ink2); }
.bg.out{ background:#e7e2f6; color:#4a3f8a; }
.bg.ok-soft{ background:#d9efe2; color:#1f6b45; }
.bg.amber-soft{ background:#fbeccf; color:#8a5e12; }
.verif{ display:inline-flex; align-items:center; gap:4px; vertical-align:middle; }
.verif .vdot{ width:17px; height:17px; border-radius:50%; background:var(--green); color:#fff; display:inline-flex; align-items:center; justify-content:center; }
.verif .vdot .ic{ width:11px; height:11px; }
.verif em{ font-style:normal; font-size:12.5px; font-weight:700; color:var(--green); }

/* ---------- date tile ---------- */
.dtile{ flex:none; width:54px; height:54px; border-radius:14px; background:var(--coral-50); border:1.5px solid var(--coral-100);
  display:flex; flex-direction:column; align-items:center; justify-content:center; }
.dtile b{ font-size:22px; font-weight:800; line-height:.9; color:var(--coral-600); }
.dtile span{ font-size:11px; font-weight:800; text-transform:uppercase; color:var(--coral); letter-spacing:.03em; }

/* ---------- page ---------- */
.pg{ max-width:1080px; margin:0 auto; padding:26px 26px 60px; display:flex; flex-direction:column; gap:22px; }
.sech{ display:flex; align-items:baseline; justify-content:space-between; gap:12px; }
.sech h2{ margin:0; font-size:21px; font-weight:800; letter-spacing:-.01em; }
.seemore{ border:0; background:transparent; color:var(--coral); font-weight:800; font-size:13.5px; display:inline-flex; align-items:center; gap:4px; text-decoration:none; }
.lead{ margin:-8px 0 0; color:var(--ink2); font-size:15px; max-width:640px; }

.hero{ padding:6px 0 2px; }
.hero-kick{ display:flex; align-items:center; gap:10px; font-size:34px; font-weight:800; letter-spacing:-.02em; line-height:1.1; }
.hero-kick > span{ color:var(--ink2); font-weight:700; }
.hero-kick .paw{ fill:var(--coral); }
.hero-sub{ margin:8px 0 0; font-size:17px; color:var(--ink2); }
.ticker{ display:inline-block; height:1.12em; line-height:1.12em; overflow:hidden; vertical-align:bottom; }
.ticker-track{ display:flex; flex-direction:column; animation:tick 13s infinite; }
.ticker .tw{ height:1.12em; line-height:1.12em; color:var(--coral); font-weight:800; white-space:nowrap; }
@media (prefers-reduced-motion:reduce){ .ticker-track{ animation:none; } }
@keyframes tick{
  0%,9.5%{transform:translateY(0)} 12.5%,22%{transform:translateY(-1.12em)}
  25%,34.5%{transform:translateY(-2.24em)} 37.5%,47%{transform:translateY(-3.36em)}
  50%,59.5%{transform:translateY(-4.48em)} 62.5%,72%{transform:translateY(-5.60em)}
  75%,84.5%{transform:translateY(-6.72em)} 87.5%,100%{transform:translateY(-7.84em)}
}

.grid-hero{ display:grid; grid-template-columns:1.5fr 1fr; gap:16px; }
.hero-side{ display:flex; flex-direction:column; gap:16px; }
.grid-2{ display:grid; grid-template-columns:1fr 1fr; gap:26px; }
.grid-2.cols{ gap:30px; }
.list{ display:flex; flex-direction:column; gap:10px; }

/* event cards */
.ev-c{ display:flex; align-items:center; gap:13px; text-align:left; width:100%; padding:12px 14px;
  background:var(--surface); border:1.5px solid var(--line); border-radius:var(--r); text-decoration:none; color:inherit; }
.ev-c:hover{ border-color:var(--coral-100); background:var(--coral-50); }
.ev-c-main{ flex:1; min-width:0; display:flex; flex-direction:column; gap:3px; }
.ev-c-main b{ font-size:15.5px; font-weight:800; }
.ev-c-org{ font-size:13px; color:var(--ink2); display:flex; align-items:center; gap:6px; flex-wrap:wrap; }
.ev-c-meta{ font-size:12.5px; color:var(--ink3); font-weight:600; display:inline-flex; align-items:center; gap:5px; }
.ev-c-meta .ic{ width:13px; height:13px; }
.ev-c-badges{ display:flex; gap:5px; flex-wrap:wrap; align-items:center; justify-content:flex-end; }

.ev-big{ display:flex; flex-direction:column; text-align:left; padding:0; overflow:hidden;
  background:var(--surface); border:1.5px solid var(--line); border-radius:var(--r-lg); text-decoration:none; color:inherit; }
.ev-big:hover{ border-color:var(--coral-100); }
.ev-banner{ position:relative; height:170px; background:var(--coral-50); display:flex; align-items:center; justify-content:center; overflow:hidden; }
.ev-banner img{ width:100%; height:100%; object-fit:cover; }
.hero-side .ev-banner{ height:104px; }
.ev-banner .paw{ opacity:.4; width:54px; height:54px; }
.ev-bz{ position:absolute; top:12px; left:12px; }
.ev-big-b{ padding:13px 16px 16px; display:flex; flex-direction:column; gap:7px; }
.ev-big-top{ display:inline-flex; align-items:center; gap:6px; font-size:13px; font-weight:700; color:var(--ink2); }
.ev-big-b b{ font-size:17px; font-weight:800; display:flex; align-items:center; gap:7px; flex-wrap:wrap; }
.hero-side .ev-big-b b{ font-size:15px; }

/* cta */
.cta{ display:flex; align-items:center; justify-content:space-between; gap:20px; padding:22px 24px;
  background:var(--coral-50); border:1.5px solid var(--coral-100); border-radius:var(--r-lg); }
.cta-t{ display:flex; align-items:center; gap:14px; }
.cta-t .paw{ fill:var(--coral); }
.cta-t b{ font-size:18px; font-weight:800; }
.cta-t p{ margin:2px 0 0; font-size:14px; color:var(--ink2); }

/* ---------- calendar ---------- */
.geo{ display:flex; flex-direction:column; gap:14px; }
.cal-bar{ display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap; }
.seg{ display:inline-flex; background:#fff; border:1.5px solid var(--line2); border-radius:999px; padding:3px; gap:2px; }
.seg button{ border:0; background:transparent; border-radius:999px; padding:6px 13px; font-weight:700; font-size:13.5px; color:var(--ink2); display:inline-flex; align-items:center; gap:6px; }
.seg button.on{ background:var(--ink); color:#fff; }
.seg button .ic{ width:15px; height:15px; }
.cal-bar-r{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.filter-seg button.on{ background:var(--coral); color:#fff; }
.filter-seg button .ic{ width:13px; height:13px; }
.cal-grid2{ display:grid; grid-template-columns:1.55fr 1fr; gap:18px; align-items:start; }
.map{ position:relative; height:380px; border:1.5px solid var(--line2); border-radius:var(--r-lg); overflow:hidden; background:#f6f1ea; }
.map-zoom{ position:absolute; top:10px; right:10px; z-index:500; display:flex; align-items:center; gap:6px; flex-wrap:wrap; justify-content:flex-end; max-width:calc(100% - 20px); }
.zbtn{ border:1.5px solid var(--line2); background:#fff; border-radius:999px; padding:6px 13px; font-weight:800; font-size:13px; color:var(--ink); white-space:nowrap; }
.map-zoom .zbtn{ box-shadow:0 1px 4px rgba(43,37,33,.14); }
.zoom-read{ font-size:11px; font-weight:800; background:var(--coral); color:#fff; border-radius:999px; padding:3px 11px; }
.map-zoom .zoom-read{ box-shadow:0 1px 4px rgba(43,37,33,.14); }
.cal-list{ display:flex; flex-direction:column; gap:8px; }
.grp{ display:flex; align-items:center; gap:8px; margin-top:8px; font-size:14px; font-weight:800; }
.grp:first-child{ margin-top:0; }
.cal-listview{ display:flex; flex-direction:column; gap:8px; max-width:760px; }
.cal-month{ border:1.5px solid var(--line2); border-radius:var(--r-lg); padding:16px; background:var(--surface); }
.cal-month-h{ display:flex; align-items:center; justify-content:center; gap:16px; margin-bottom:12px; }
.cal-month-h b{ font-size:18px; font-weight:800; min-width:170px; text-align:center; }
.cal-next{ transform:scaleX(-1); }
.cal-dows{ display:grid; grid-template-columns:repeat(7,1fr); gap:6px; margin-bottom:6px; }
.cal-dows span{ font-size:11px; font-weight:800; color:var(--ink3); text-align:center; text-transform:uppercase; letter-spacing:.04em; }
.cal-cells{ display:grid; grid-template-columns:repeat(7,1fr); gap:6px; }
.cal-cell{ min-height:78px; border:1.5px solid var(--line); border-radius:12px; padding:5px 5px 6px; background:#fff; display:flex; flex-direction:column; gap:3px; }
.cal-cell.empty{ border:0; background:transparent; min-height:0; }
.cal-cell.has{ border-color:var(--coral-100); }
.cal-dn{ font-size:11.5px; font-weight:800; color:var(--ink3); }
.cal-chip{ display:block; width:100%; text-align:left; border:0; border-radius:7px; padding:3px 7px; font-size:11px; font-weight:800; line-height:1.25; color:#fff; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; text-decoration:none; }
.cal-chip.ch{ background:var(--red); } .cal-chip.out{ background:var(--blue); }
.cal-chip:hover{ filter:brightness(.94); }
.map-legend{ display:flex; gap:7px; align-items:center; z-index:500; }
.map-legend.pad{ position:static; margin-top:12px; }
.lg{ display:inline-flex; align-items:center; gap:5px; font-size:11px; font-weight:800; background:#fff; border:1px solid var(--line2); border-radius:999px; padding:3px 9px; }
.lg::before{ content:""; width:9px; height:9px; border-radius:50%; }
.lg.ch::before{ background:var(--red); } .lg.out::before{ background:var(--blue); }

/* leaflet */
.map-wrap{ position:relative; }
.map-wrap.small .map{ height:240px; }
.leaflet-container{ font:inherit; background:#eef0ee; border-radius:var(--r-lg); }
.map .leaflet-control-zoom{ border:0; box-shadow:0 1px 4px rgba(0,0,0,.12); border-radius:12px; overflow:hidden; }
.map .leaflet-control-zoom a{ background:#fff; color:var(--ink); border:0; font-weight:800; }
.map .leaflet-control-zoom a:hover{ background:var(--coral-50); color:var(--coral-600); }
.leaflet-control-attribution{ font-size:10px; background:rgba(255,255,255,.8); }
.pmwrap{ background:none; border:0; }
.pm{ display:block; width:16px; height:16px; border-radius:50% 50% 50% 0; transform:rotate(-45deg);
  background:var(--red); border:2px solid #fff; box-shadow:0 0 0 1.5px var(--red), 0 2px 5px rgba(0,0,0,.3); }
.pm.out{ background:var(--blue); box-shadow:0 0 0 1.5px var(--blue), 0 2px 5px rgba(0,0,0,.3); }
.pm-tip{ background:#fff; border:1.5px solid var(--line2); border-radius:8px; color:var(--ink); font-weight:800; font-size:12px; box-shadow:0 4px 12px rgba(0,0,0,.1); }
.pm-tip::before{ display:none; }
.map.map-static{ display:flex; align-items:center; justify-content:center; }
.map-fb{ font-size:13px; font-weight:700; color:var(--ink2); text-align:center; padding:20px; }

/* ---------- auth ---------- */
.auth{ display:grid; grid-template-columns:1fr 1fr; min-height:calc(100vh - 64px); }
.auth-brand{ position:relative; overflow:hidden; background:var(--coral); color:#fff; padding:48px 44px; display:flex; align-items:center; }
.pawpat{ position:absolute; inset:0; display:flex; flex-wrap:wrap; gap:34px; padding:26px; opacity:.55; }
.pawpat .paw{ fill:#fff; opacity:.4; transform:rotate(-16deg); }
.auth-brand-in{ position:relative; display:flex; flex-direction:column; gap:16px; max-width:340px; }
.auth-brand-in h1{ font-size:30px; font-weight:800; margin:0; line-height:1.12; }
.auth-brand-in p{ margin:0; font-size:15px; opacity:.92; }
.auth-form{ padding:44px; display:flex; flex-direction:column; gap:20px; justify-content:center; max-width:480px; margin:0 auto; width:100%; }
.auth-tabs{ align-self:flex-start; }
.auth-tabs button{ padding:8px 20px; font-size:14.5px; }
.auth-fields{ display:flex; flex-direction:column; gap:15px; }
.auth-fields[hidden]{ display:none; }
.field{ display:flex; flex-direction:column; gap:6px; }
.flab{ font-size:13px; font-weight:700; color:var(--ink2); }
.flab i{ color:var(--coral); font-style:normal; }
.field input,.field textarea,.field select{ font-family:inherit; font-size:15px; color:var(--ink); background:#fff;
  border:1.6px solid var(--line2); border-radius:12px; padding:11px 13px; width:100%; }
.field textarea{ resize:vertical; }
.field input:focus,.field textarea:focus,.field select:focus{ outline:none; border-color:var(--coral); box-shadow:0 0 0 3px var(--coral-50); }
.selwrap{ position:relative; display:flex; }
.selwrap select{ appearance:none; padding-right:34px; }
.selwrap .caret{ position:absolute; right:10px; top:50%; transform:translateY(-50%) rotate(-90deg); color:var(--ink3); pointer-events:none; }
.fhint{ font-size:11.5px; color:var(--ink3); font-weight:600; }
.row-split{ display:flex; align-items:center; justify-content:space-between; gap:10px; }
.chk{ display:flex; align-items:center; gap:8px; font-size:13.5px; color:var(--ink2); font-weight:600; }
.chk input{ width:16px; height:16px; accent-color:var(--coral); }
.link{ border:0; background:transparent; color:var(--coral); font-weight:800; font-size:13px; text-decoration:none; }
.or{ display:flex; align-items:center; gap:12px; color:var(--ink3); font-size:12px; font-weight:700; }
.or::before,.or::after{ content:""; flex:1; height:1.5px; background:var(--line); }
.fine{ font-size:12px; color:var(--ink3); text-align:center; margin:2px 0 0; font-weight:600; }
.auth-tg{ display:flex; flex-direction:column; gap:8px; }

/* telegram + turnstile */
.tg-btn{ display:inline-flex; align-items:center; justify-content:center; gap:9px; width:100%; background:#229ed9; color:#fff;
  border:0; border-radius:12px; padding:12px 16px; font-family:var(--f); font-weight:800; font-size:15px; line-height:1; transition:background .16s ease, transform .12s ease; text-decoration:none; }
.tg-btn:hover{ background:#1b8cc2; }
.tg-btn:active{ transform:scale(.98); }
.tg-btn .ic{ color:#fff; }
.tg-hint{ font-size:11.5px; color:var(--ink3); font-weight:600; text-align:center; margin:0; }
.cf-turnstile{ display:flex; align-items:center; gap:12px; background:#fafafa; border:1px solid #e1e1e1; border-radius:8px; padding:11px 13px; width:100%; max-width:320px; }

/* ---------- event detail ---------- */
.ev-detail{ gap:18px; }
.ev-detail .crumb{ align-self:flex-start; }
.crumb{ border:0; background:transparent; color:var(--ink2); font-weight:700; font-size:14px; display:inline-flex; align-items:center; gap:4px; text-decoration:none; }
.ev-hero{ position:relative; height:230px; border-radius:var(--r-lg); background:var(--coral-100);
  display:flex; align-items:center; justify-content:center; overflow:hidden; }
.ev-hero img{ width:100%; height:100%; object-fit:cover; }
.ev-hero .paw{ opacity:.4; width:70px; height:70px; }
.ev-hero-badges{ position:absolute; top:14px; left:14px; display:flex; gap:6px; }
.ev-d-grid{ display:grid; grid-template-columns:1fr 320px; gap:28px; align-items:start; }
.ev-d-main{ display:flex; flex-direction:column; gap:16px; min-width:0; }
.ev-d-main h1{ margin:0; font-size:30px; font-weight:800; letter-spacing:-.01em; }
.ev-d-sub{ margin:0; font-size:16px; color:var(--ink2); }
.ev-d-facts{ display:flex; flex-wrap:wrap; gap:12px; }
.fact{ display:flex; align-items:center; gap:11px; flex:1; min-width:220px; background:var(--surface); border:1.5px solid var(--line); border-radius:var(--r); padding:13px 15px; }
.fact .ic{ color:var(--coral); flex:none; }
.fact b{ font-size:15px; font-weight:800; display:block; }
.fact span{ font-size:13px; color:var(--ink2); }
.ev-badges-row{ display:flex; flex-wrap:wrap; gap:7px; }
.ev-desc h2{ margin:0 0 10px; font-size:19px; font-weight:800; }
.ev-desc p{ margin:0 0 12px; color:var(--ink); font-size:15.5px; }
.ev-desc ul{ margin:0; padding-left:20px; color:var(--ink2); font-size:14.5px; display:flex; flex-direction:column; gap:6px; }
.ev-links{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; padding-top:4px; }
.ev-links-lab{ font-weight:800; font-size:14px; }
.ev-d-side{ display:flex; flex-direction:column; gap:12px; position:sticky; top:14px; }
.org-card{ border:1.5px solid var(--line); border-radius:var(--r); padding:16px; display:flex; flex-direction:column; gap:13px; background:var(--surface); }
.org-top{ display:flex; align-items:center; gap:11px; }
.org-logo{ width:46px; height:46px; border-radius:14px; background:var(--coral-50); border:1.5px solid var(--coral-100); display:flex; align-items:center; justify-content:center; flex:none; overflow:hidden; }
.org-logo img{ width:100%; height:100%; object-fit:cover; }
.org-logo .paw{ fill:var(--coral); }
.org-meta b{ font-size:15px; font-weight:800; display:flex; align-items:center; gap:6px; flex-wrap:wrap; }
.org-meta span{ font-size:12.5px; color:var(--ink2); }
.side-note{ display:flex; align-items:center; gap:8px; font-size:13px; font-weight:700; color:var(--ink2); justify-content:center; }
.side-note .ic{ color:var(--coral); }
.langrow{ display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.langrow-lab{ font-size:13px; font-weight:800; color:var(--ink3); text-transform:uppercase; letter-spacing:.04em; }
.lchipv{ font-size:12px; font-weight:800; border:1.5px solid var(--line2); border-radius:999px; padding:3px 11px; background:#fff; color:var(--ink2); }
.lchipv.orig{ background:var(--coral-50); border-color:var(--coral-100); color:var(--coral-600); }

/* ---------- organizations directory ---------- */
.org-toolbar{ display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap; }
.srch{ display:inline-flex; align-items:center; gap:8px; background:#fff; border:1.5px solid var(--line2); border-radius:999px; padding:9px 16px; color:var(--ink3); font-weight:600; font-size:14px; flex:1; min-width:200px; max-width:360px; }
.orgv-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.orgv{ display:flex; flex-direction:column; gap:11px; background:var(--surface); border:1.5px solid var(--line); border-radius:var(--r-lg); padding:18px; text-decoration:none; color:inherit; }
.orgv[data-route]:hover{ border-color:var(--coral-100); }
.orgv-top{ display:flex; align-items:center; gap:12px; }
.org-logo.lg{ width:52px; height:52px; border-radius:16px; }
.org-logo.xl{ width:64px; height:64px; border-radius:20px; flex:none; }
.orgv-meta b{ font-size:16px; font-weight:800; display:flex; align-items:center; gap:6px; flex-wrap:wrap; }
.orgv-sub{ font-size:12.5px; color:var(--ink2); }
.orgv-desc{ margin:0; font-size:14px; color:var(--ink2); flex:1; }
.orgv-foot{ display:flex; align-items:center; justify-content:space-between; gap:10px; border-top:1px solid var(--line); padding-top:11px; }
.orgv-stats{ display:inline-flex; align-items:center; gap:6px; font-size:12.5px; font-weight:700; color:var(--ink2); }
.orgv-stats .ic{ color:var(--coral); }

/* ---------- organisation detail ---------- */
.org-detail{ gap:18px; }
.org-detail .crumb{ align-self:flex-start; }
.od-hero{ position:relative; overflow:hidden; background:var(--coral-50); border:1.5px solid var(--coral-100); border-radius:var(--r-lg); padding:26px 28px; }
.od-hero .pawpat{ opacity:.45; }
.od-hero .pawpat .paw{ fill:var(--coral); opacity:.3; }
.od-hero-in{ position:relative; display:flex; align-items:center; gap:18px; flex-wrap:wrap; }
.od-head{ flex:1; min-width:200px; }
.od-head h1{ margin:0; font-size:26px; font-weight:800; display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.od-sub{ font-size:13.5px; color:var(--ink2); font-weight:600; display:inline-flex; align-items:center; gap:7px; flex-wrap:wrap; }
.od-actions{ display:flex; gap:9px; flex-wrap:wrap; }
.od-stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:12px; }
.stat{ background:var(--surface); border:1.5px solid var(--line); border-radius:var(--r); padding:14px 16px; text-align:center; }
.stat b{ display:block; font-size:24px; font-weight:800; letter-spacing:-.01em; }
.stat span{ font-size:12px; font-weight:700; color:var(--ink3); text-transform:uppercase; letter-spacing:.04em; }
.od-desc{ margin:0; font-size:15.5px; color:var(--ink); }
.od-verif{ display:flex; align-items:center; gap:8px; margin-top:13px; font-size:14px; color:var(--ink2); background:#d9efe2; border-radius:var(--r); padding:11px 14px; }
.od-verif b{ color:#1f6b45; } .od-verif .ic{ color:#1f6b45; flex:none; }
.od-verif.pending{ background:#fbeccf; } .od-verif.pending .ic{ color:#8a5e12; }
.empty-note{ display:flex; align-items:center; gap:8px; font-size:14px; color:var(--ink3); font-weight:600; border:1.5px dashed var(--line2); border-radius:var(--r); padding:16px; }
.empty-note .paw{ fill:var(--coral); }
.kick{ display:inline-flex; align-items:center; gap:6px; white-space:nowrap; font-size:12px; font-weight:800; letter-spacing:.04em; text-transform:uppercase; color:var(--coral-600); }
.kick .paw{ fill:var(--coral); }

/* ---------- footer ---------- */
.site-foot{ display:flex; flex-direction:column; align-items:center; gap:5px; padding:34px 20px 36px; border-top:1px solid var(--line); text-align:center; background:var(--bg); }
.foot-cols{ width:100%; max-width:620px; display:flex; justify-content:space-between; gap:40px; flex-wrap:wrap; text-align:left; padding-bottom:22px; margin-bottom:18px; border-bottom:1px solid var(--line); }
.foot-col{ display:flex; flex-direction:column; gap:11px; }
.foot-col .foot-h{ font-size:16px; font-weight:800; color:var(--ink); margin-bottom:3px; letter-spacing:-.01em; }
.foot-col a{ font-size:14px; font-weight:700; color:var(--coral-600); text-decoration:none; width:fit-content; }
.foot-col a:hover{ color:var(--coral); text-decoration:underline; }
.site-foot .pb{ display:inline-flex; align-items:center; gap:6px; font-weight:800; font-size:14.5px; color:var(--ink); }
.site-foot .pb .paw{ fill:var(--coral); }
.site-foot .pb b{ color:var(--coral-600); }
.site-foot .cprt{ font-size:12px; color:var(--ink3); font-weight:600; }

/* ---------- animations ---------- */
@keyframes rise{ from{ opacity:0; transform:translateY(12px); } to{ opacity:1; transform:none; } }
@keyframes fadeIn{ from{ opacity:0; } to{ opacity:1; } }
.ev-c, .ev-big, .orgv, .stat{ transition:transform .16s ease, border-color .16s ease, background .16s ease, box-shadow .16s ease; }
.ev-c:hover, .orgv[data-route]:hover{ transform:translateY(-2px); }
.ev-big:hover{ transform:translateY(-3px); box-shadow:0 10px 26px rgba(43,37,33,.08); }
.stat:hover{ transform:translateY(-2px); border-color:var(--coral-100); }
.btn{ transition:transform .12s ease, background .16s ease, border-color .16s ease, color .16s ease; }
.btn:active{ transform:scale(.96); }
@media (prefers-reduced-motion: no-preference){
  main.pg > *{ animation:rise .5s both cubic-bezier(.2,.7,.2,1); }
  main.pg > *:nth-child(1){ animation-delay:.02s; }
  main.pg > *:nth-child(2){ animation-delay:.07s; }
  main.pg > *:nth-child(3){ animation-delay:.12s; }
  main.pg > *:nth-child(4){ animation-delay:.17s; }
  main.pg > *:nth-child(5){ animation-delay:.22s; }
  main.pg > *:nth-child(6){ animation-delay:.27s; }
  main.pg > *:nth-child(n+7){ animation-delay:.3s; }
  .ph{ animation:fadeIn .4s both; }
  .site-foot{ animation:fadeIn .6s both .2s; }
}

/* ---------- responsive ---------- */
@media (max-width:820px){
  .pnav{ display:none; }
  .ph-r .lang{ display:none; }
  .ph-r .btn{ display:none; }
  .only-m{ display:inline-flex; }
  .ph{ padding:12px 18px; position:relative; }
  .ph.open .ph-menu{ display:flex; }
  .ph-menu{ position:absolute; top:100%; right:14px; left:14px; flex-direction:column; gap:2px; background:#fff;
    border:1.5px solid var(--line2); border-radius:var(--r); padding:8px; box-shadow:0 12px 30px rgba(0,0,0,.1); }
  .ph-menu a, .ph-menu button{ border:0; background:transparent; text-align:left; padding:11px 12px; border-radius:10px; font-weight:700; font-size:15px; color:var(--ink); display:flex; align-items:center; gap:8px; text-decoration:none; }
  .ph-menu a:hover, .ph-menu button:hover{ background:var(--coral-50); }
  .ph-menu .m-primary{ background:var(--coral); color:#fff; } .ph-menu .m-primary .paw{ fill:#fff; }
  .ph-menu hr{ border:0; border-top:1px solid var(--line); margin:4px 6px; width:100%; }
  .pg{ padding:20px 16px 50px; gap:18px; }
  .hero-kick{ font-size:25px; } .hero-sub{ font-size:15px; }
  .grid-hero{ grid-template-columns:1fr; }
  .grid-2,.grid-2.cols{ grid-template-columns:1fr; gap:22px; }
  .cal-grid2{ grid-template-columns:1fr; }
  .map{ height:300px; }
  .cta{ flex-direction:column; align-items:flex-start; gap:14px; }
  .ev-d-grid{ grid-template-columns:1fr; gap:20px; }
  .ev-d-side{ position:static; }
  .ev-hero{ height:160px; }
  .ev-d-main h1{ font-size:24px; }
  .od-stats{ grid-template-columns:repeat(2,1fr); }
  .od-head h1{ font-size:22px; }
  .orgv-grid{ grid-template-columns:1fr; }
  .auth{ grid-template-columns:1fr; }
  .auth-brand{ padding:30px 26px; } .auth-brand-in h1{ font-size:24px; }
  .auth-form{ padding:26px 22px; }
}
@media (max-width:480px){
  .hero-kick{ font-size:21px; flex-wrap:wrap; }
  .sech h2{ font-size:18px; }
}

/* ---------- 404 ---------- */
.e404{ position:relative; display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding:44px 24px 56px; overflow:hidden; min-height:62vh; }
.e404-num{ font-size:clamp(120px, 26vw, 230px); font-weight:900; line-height:.86; letter-spacing:-.04em;
  color:var(--coral); margin:0; position:relative; z-index:2; }
.e404-num span{ color:var(--ink); }
.e404-kick{ display:inline-flex; align-items:center; gap:7px; font-size:13px; font-weight:800; letter-spacing:.06em;
  text-transform:uppercase; color:var(--coral-600); margin-bottom:6px; position:relative; z-index:2; }
.e404-kick .paw{ fill:var(--coral); }
.e404 h1{ margin:6px 0 0; font-size:clamp(26px, 4vw, 38px); font-weight:800; letter-spacing:-.02em; position:relative; z-index:2; }
.e404 p.e404-lead{ margin:14px auto 0; max-width:480px; font-size:16.5px; color:var(--ink2); position:relative; z-index:2; }
.e404-btns{ display:flex; gap:11px; flex-wrap:wrap; justify-content:center; margin-top:26px; position:relative; z-index:2; }
.e404 .btn .paw{ fill:currentColor; }
.speed{ position:absolute; top:14%; left:50%; transform:translateX(-50%); width:min(880px, 92vw); height:60%;
  z-index:1; opacity:.5; pointer-events:none; }
.speed line{ stroke:var(--coral-100); stroke-width:5; stroke-linecap:round; stroke-dasharray:2 22; }
.e404-jet{ position:relative; z-index:3; width:100%; pointer-events:none; display:flex; justify-content:center; margin:-6px 0 2px; }
.e404-jet img{ width:min(540px, 82vw); height:auto; display:block; filter:drop-shadow(0 22px 26px rgba(43,37,33,.16)); transform-origin:center; }
.e404-mini{ font-size:13px; color:var(--ink3); font-weight:700; margin-top:18px; position:relative; z-index:2; }
.e404-mini code{ background:#fff; border:1.5px solid var(--line2); border-radius:7px; padding:2px 8px; font-family:inherit; color:var(--ink); font-weight:800; }
@media (prefers-reduced-motion: no-preference){
  .e404-jet img{ animation:hover-fly 4.5s ease-in-out infinite; }
  .e404 .e404-num, .e404 h1, .e404 p.e404-lead, .e404-btns{ animation:rise404 .6s cubic-bezier(.2,.7,.2,1) both; }
  .e404 h1{ animation-delay:.06s; } .e404 p.e404-lead{ animation-delay:.12s; } .e404-btns{ animation-delay:.18s; }
}
@keyframes hover-fly{ 0%,100%{ transform:translateY(0) rotate(-.6deg); } 50%{ transform:translateY(-14px) rotate(.6deg); } }
@keyframes rise404{ from{ transform:translateY(18px); } to{ transform:none; } }
@media (max-width:560px){ .e404-jet img{ width:92vw; } }

/* ---------- organizer info ---------- */
.org-hero{ position:relative; overflow:hidden; background:var(--coral-50); border:1.5px solid var(--coral-100); border-radius:var(--r-lg); padding:34px 32px; }
.org-hero .pawpat{ opacity:.5; }
.org-hero .pawpat .paw{ fill:var(--coral); opacity:.32; }
.org-hero-in{ position:relative; max-width:600px; }
.org-hero-in > * + *{ margin-top:13px; }
.org-hero-in h1{ margin:0; font-size:30px; font-weight:800; line-height:1.14; letter-spacing:-.01em; }
.org-hero-in p{ margin:0; font-size:15.5px; color:var(--ink2); }
.hero-btns{ display:flex; gap:10px; margin-top:4px; flex-wrap:wrap; }
.checklist{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:9px; }
.checklist li{ display:flex; align-items:center; gap:10px; font-size:14.5px; font-weight:600; background:var(--surface); border:1.5px solid var(--line); border-radius:var(--r); padding:12px 15px; }
.checklist li .paw{ fill:var(--coral); flex:none; }
.pipe-wrap{ margin-top:16px; }
.pipe-lab{ font-size:12px; font-weight:800; text-transform:uppercase; letter-spacing:.04em; color:var(--ink3); display:block; margin-bottom:8px; }
.pipe{ display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.pstep{ font-size:12.5px; font-weight:800; border:1.5px solid var(--line2); border-radius:999px; padding:5px 13px; background:#fff; color:var(--ink3); }
.pstep.on{ border-color:var(--ink); color:var(--ink); border-style:dashed; }
.pstep.ok{ background:var(--green); color:#fff; border-color:var(--green); display:inline-flex; align-items:center; gap:5px; }
.parr{ color:var(--ink3); display:inline-flex; }
.faqs{ display:flex; flex-direction:column; gap:10px; }
.faq{ border:1.5px solid var(--line); border-radius:var(--r); background:var(--surface); overflow:hidden; }
.faq-q{ width:100%; text-align:left; border:0; background:transparent; padding:14px 16px; font-weight:800; font-size:14.5px; display:flex; align-items:center; justify-content:space-between; gap:10px; }
.faq .chev{ color:var(--coral); transition:transform .2s; transform:rotate(-90deg); display:inline-flex; }
.faq.open .chev{ transform:rotate(90deg); }
.faq-a{ padding:0 16px 14px; font-size:14px; color:var(--ink2); }
.faq:not(.open) .faq-a{ display:none; }

/* ---------- legal / prose ---------- */
.prose-legal{ max-width:760px; }
.prose-legal h1{ font-size:28px; font-weight:800; letter-spacing:-.01em; margin:0 0 6px; }
.prose-legal h2{ font-size:19px; font-weight:800; margin:26px 0 8px; }
.prose-legal h3{ font-size:15.5px; font-weight:800; margin:18px 0 6px; }
.prose-legal p, .prose-legal li{ font-size:15px; color:var(--ink2); line-height:1.6; }
.prose-legal a{ color:var(--coral-600); font-weight:700; }
.prose-legal ul{ padding-left:20px; display:flex; flex-direction:column; gap:5px; }
.prose-legal .lead{ margin:0 0 18px; }

/* ========== EASTER EGG: NORSK MODUS ========== */
@keyframes noBuzz{
  0%,100%{ transform:translate(0,0) rotate(0); }
  20%{ transform:translate(-1.2px,1px) rotate(-4deg); }
  40%{ transform:translate(1.2px,-1px) rotate(4deg); }
  60%{ transform:translate(-1px,-1.2px) rotate(-3deg); }
  80%{ transform:translate(1px,1.2px) rotate(3deg); }
}
#noCursor{ position:fixed; left:0; top:0; z-index:6000; pointer-events:none; display:none; will-change:transform; }
#noCursor.show{ display:block; }
#noCursor .c-in{ display:block; animation:noBuzz .08s linear infinite; transform-origin:top left; filter:drop-shadow(0 1px 2px rgba(0,0,0,.35)); }
#noCursor .buzzlbl{ position:absolute; left:20px; top:16px; background:var(--ink); color:#fff; font-family:var(--f);
  font-size:11px; font-weight:800; padding:2px 7px; border-radius:999px; white-space:nowrap; animation:noBuzz .1s linear infinite; }

html.norsk{ --coral:#ba0c2f; --coral-600:#8e0823; --coral-100:#f3ccd4; --coral-50:#fbe9ed; --red:#ba0c2f; --blue:#00205b; }
html.norsk .brand b span{ color:#00205b; }
html.norsk .dtile b{ color:#00205b; }
html.norsk .pnav a.on{ color:#00205b; }

.no-flag{ width:30px; height:22px; border-radius:3px; flex:none;
  background:
    linear-gradient(#00205b,#00205b) 8px 0/4px 100% no-repeat,
    linear-gradient(#00205b,#00205b) 0 9px/100% 4px no-repeat,
    linear-gradient(#fff,#fff) 6px 0/8px 100% no-repeat,
    linear-gradient(#fff,#fff) 0 7px/100% 8px no-repeat,
    #ba0c2f;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.06); }

.norsk-dialog{ position:fixed; right:22px; bottom:22px; z-index:5500; width:312px; max-width:calc(100vw - 32px);
  background:#fff; border:1.5px solid var(--line2); border-radius:18px; overflow:hidden;
  box-shadow:0 20px 50px rgba(0,0,0,.24); font-family:var(--f); animation:ndIn .34s cubic-bezier(.2,.7,.2,1) both; }
.norsk-dialog .nd-bar{ height:7px; background:linear-gradient(90deg,#ba0c2f 0 38%,#fff 38% 50%,#00205b 50% 62%,#fff 62% 74%,#ba0c2f 74% 100%); }
.norsk-dialog .nd-body{ padding:16px 17px 17px; display:flex; flex-direction:column; gap:11px; }
.norsk-dialog .nd-top{ display:flex; align-items:center; gap:11px; }
.norsk-dialog .nd-top b{ font-size:15.5px; font-weight:800; color:var(--ink); }
.norsk-dialog .nd-top span{ font-size:12px; font-weight:700; color:var(--ink3); }
.norsk-dialog p{ margin:0; font-size:13.5px; color:var(--ink2); line-height:1.5; }
.norsk-dialog .nd-btns{ display:flex; gap:8px; margin-top:2px; }
.norsk-dialog .nd-btns .btn{ flex:1; }
@keyframes ndIn{ from{ opacity:0; transform:translateY(18px) scale(.96); } to{ opacity:1; transform:none; } }

/* ---------- mein bereich (dashboard) ---------- */
.mein-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:16px; flex-wrap:wrap; }
.mein-head h1{ margin:4px 0 0; font-size:28px; font-weight:800; letter-spacing:-.01em; }
.mein-actions{ display:flex; gap:10px; flex-wrap:wrap; }
.myorg{ display:flex; align-items:center; gap:12px; background:var(--surface); border:1.5px solid var(--line); border-radius:var(--r); padding:12px 14px; text-decoration:none; color:inherit; transition:transform .16s ease, border-color .16s ease, background .16s ease; }
.myorg[href]:hover{ border-color:var(--coral-100); background:var(--coral-50); transform:translateY(-2px); }
.myorg-meta{ flex:1; min-width:0; }
.myorg-meta b{ font-size:15px; font-weight:800; display:flex; align-items:center; gap:6px; flex-wrap:wrap; }
.myorg-meta span{ font-size:12.5px; color:var(--ink2); }
.myev{ display:flex; align-items:center; gap:13px; background:var(--surface); border:1.5px solid var(--line); border-radius:var(--r); padding:11px 14px; text-decoration:none; color:inherit; transition:transform .16s ease, border-color .16s ease, background .16s ease; }
.myev[href]:hover{ border-color:var(--coral-100); background:var(--coral-50); transform:translateY(-2px); }
.myev-meta{ flex:1; min-width:0; }
.myev-meta b{ font-size:15px; font-weight:800; }
.myev-meta span{ font-size:12.5px; color:var(--ink2); display:block; }
.vreq{ background:var(--surface); border:1.5px solid var(--line); border-radius:var(--r-lg); padding:16px; display:flex; flex-direction:column; gap:11px; }
.vreq-top{ display:flex; align-items:center; justify-content:space-between; gap:10px; }
.vreq-top b{ font-size:15px; font-weight:800; }
.vreq p{ margin:0; font-size:13.5px; color:var(--ink2); }
@media (max-width:820px){ .mein-actions{ width:100%; } .mein-actions .btn{ flex:1; } }

/* ---------- settings / profil ---------- */
.form-top{ display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.crumb-now{ font-weight:800; font-size:18px; }
.settings{ gap:18px; max-width:760px; }
.set-card{ background:var(--surface); border:1.5px solid var(--line); border-radius:var(--r-lg); padding:20px 22px; display:flex; flex-direction:column; gap:15px; }
.set-card-h{ display:flex; align-items:center; gap:11px; }
.set-card-h .set-ic{ width:38px; height:38px; border-radius:11px; background:var(--coral-50); border:1.5px solid var(--coral-100); color:var(--coral-600); display:flex; align-items:center; justify-content:center; flex:none; }
.set-card-h b{ font-size:16.5px; font-weight:800; }
.set-card-h span{ display:block; font-size:12.5px; color:var(--ink2); font-weight:600; margin-top:1px; }
.set-card-foot{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.set-note{ font-size:12.5px; color:var(--ink3); font-weight:600; display:flex; align-items:center; gap:7px; margin:0; }
.set-note .paw{ fill:var(--coral); }
.set-current{ display:flex; align-items:center; gap:8px; font-size:13.5px; color:var(--ink2); background:var(--bg); border:1.5px solid var(--line); border-radius:10px; padding:9px 12px; word-break:break-all; }
.set-current .ic{ color:var(--coral); flex:none; }
.set-current b{ color:var(--ink); }
.tg-link{ display:flex; align-items:center; gap:13px; background:var(--bg); border:1.5px solid var(--line); border-radius:var(--r); padding:13px 15px; flex-wrap:wrap; }
.tg-link .tg-av{ width:44px; height:44px; border-radius:12px; background:#e7f4fb; color:#229ed9; display:flex; align-items:center; justify-content:center; flex:none; overflow:hidden; }
.tg-link .tg-av img{ width:100%; height:100%; object-fit:cover; }
.tg-link-meta{ flex:1; min-width:140px; }
.tg-link-meta b{ font-size:15px; font-weight:800; display:flex; align-items:center; gap:7px; flex-wrap:wrap; }
.tg-link-meta span{ font-size:12.5px; color:var(--ink2); }
.tg-state{ font-size:11.5px; font-weight:800; border-radius:999px; padding:3px 10px; display:inline-flex; align-items:center; gap:5px; }
.tg-state.on{ background:#d9efe2; color:#1f6b45; }
.tg-state.off{ background:#fbeccf; color:#8a5e12; }
.g2{ display:grid; grid-template-columns:1fr 1fr; gap:13px; }
@media (max-width:820px){ .g2{ grid-template-columns:1fr; } }
.danger-card{ border-color:#f3c9c4; }
.danger-card .set-card-h .set-ic{ background:#fbe3e0; border-color:#f3c9c4; color:var(--red); }

/* ---------- coming soon (disabled action + tooltip) ---------- */
.soon{ position:relative; display:inline-flex; }
.btn.is-disabled{ opacity:.6; cursor:not-allowed; background:var(--line); color:var(--ink3); border-color:var(--line2); pointer-events:none; }
.soon::after{ content:attr(data-soon); position:absolute; bottom:calc(100% + 9px); left:50%; transform:translateX(-50%) translateY(4px);
  background:var(--ink); color:#fff; font-size:11.5px; font-weight:800; padding:5px 10px; border-radius:8px; white-space:nowrap;
  opacity:0; pointer-events:none; transition:opacity .16s ease, transform .16s ease; box-shadow:0 8px 20px rgba(0,0,0,.2); z-index:60; }
.soon::before{ content:""; position:absolute; bottom:calc(100% + 4px); left:50%; transform:translateX(-50%); border:5px solid transparent;
  border-top-color:var(--ink); opacity:0; transition:opacity .16s ease; z-index:60; }
.soon:hover::after{ opacity:1; transform:translateX(-50%) translateY(0); }
.soon:hover::before{ opacity:1; }
.link.is-disabled{ opacity:.55; cursor:not-allowed; text-decoration:none; }

/* ---------- event create form ---------- */
.wiz{ display:flex; flex-direction:column; gap:18px; background:var(--surface); border:1.5px solid var(--line); border-radius:var(--r-lg); padding:22px; }
.wiz .step-h{ margin:0 0 6px; font-size:16px; font-weight:800; }
.wiz-sec{ display:flex; flex-direction:column; gap:13px; }
.wiz-sec + .wiz-sec{ border-top:1px solid var(--line); padding-top:18px; }
.tg{ display:flex; align-items:center; gap:9px; font-size:14px; font-weight:600; color:var(--ink); cursor:pointer; user-select:none; position:relative; }
.tg input{ position:absolute; opacity:0; width:0; height:0; }
.tg .sw{ width:40px; height:22px; border-radius:999px; background:#e2dace; position:relative; flex:none; transition:.18s; }
.tg .sw i{ position:absolute; top:2px; left:2px; width:18px; height:18px; border-radius:50%; background:#fff; transition:.18s; box-shadow:0 1px 2px rgba(0,0,0,.15); }
.tg input:checked + .sw{ background:var(--coral); }
.tg input:checked + .sw i{ left:20px; }
.hint-note{ display:flex; align-items:center; gap:8px; font-size:13px; color:var(--ink2); background:var(--coral-50); border-radius:12px; padding:10px 13px; }
.hint-note .paw{ fill:var(--coral); }
.link-item{ display:grid; grid-template-columns:1fr 1.4fr auto; gap:9px; align-items:center; }
.link-item .btn-x{ border:1.5px solid var(--line2); background:#fff; border-radius:10px; width:42px; height:42px; font-weight:800; color:var(--ink3); cursor:pointer; flex:none; }
@media (max-width:820px){ .link-item{ grid-template-columns:1fr 1fr; } }
.wiz-foot{ display:flex; align-items:center; justify-content:flex-end; gap:12px; }

/* ---------- event wizard (steps) ---------- */
.form-top-r{ margin-left:auto; display:flex; align-items:center; gap:9px; }
.steps{ display:flex; gap:8px; overflow-x:auto; padding-bottom:2px; }
.wstep{ flex:1; min-width:108px; border:1.5px solid var(--line2); background:#fff; border-radius:12px; padding:10px 12px;
  font-weight:700; font-size:13.5px; color:var(--ink2); display:flex; align-items:center; gap:8px; white-space:nowrap; cursor:pointer; }
.wstep .wn{ width:22px; height:22px; border-radius:50%; background:#f1ece4; color:var(--ink2); display:inline-flex; align-items:center; justify-content:center; font-size:12px; font-weight:800; flex:none; }
.wstep.on{ border-color:var(--coral); color:var(--ink); background:var(--coral-50); }
.wstep.on .wn{ background:var(--coral); color:#fff; }
.wstep.done .wn{ background:var(--green); color:#fff; }
.wiz-body{ display:grid; grid-template-columns:1.5fr 1fr; gap:20px; align-items:start; }
.wiz-main{ display:flex; flex-direction:column; gap:13px; min-width:0; }
.wiz-step[hidden]{ display:none; }
.wiz-prog{ font-size:13px; font-weight:800; color:var(--ink3); }
.ev-prev{ border:1.5px solid var(--line); border-radius:var(--r); overflow:hidden; position:sticky; top:14px; }
.pv-lab{ font-size:11px; font-weight:800; letter-spacing:.08em; text-transform:uppercase; color:var(--ink3); padding:9px 14px; border-bottom:1px solid var(--line); }
.pv-banner{ height:96px; background:var(--coral-50); display:flex; align-items:center; justify-content:center; overflow:hidden; }
.pv-banner img{ width:100%; height:100%; object-fit:cover; }
.pv-banner .paw{ opacity:.4; }
.pv-b{ padding:12px 15px 15px; display:flex; flex-direction:column; gap:7px; }
.pv-b b{ font-size:16px; font-weight:800; display:flex; align-items:center; gap:6px; flex-wrap:wrap; }
@media (max-width:820px){
  .wiz-body{ grid-template-columns:1fr; }
  .ev-prev{ order:-1; position:static; }
  .form-top-r{ width:100%; }
}

/* ---------- series panel ---------- */
.series-panel{ margin-top:6px; border:1.5px solid var(--coral-100); background:var(--coral-50); border-radius:var(--r); padding:16px 18px; display:flex; flex-direction:column; gap:14px; }
.series-panel[hidden]{ display:none; }
.series-panel .field input, .series-panel .field select{ background:#fff; }
.sp-head{ display:flex; align-items:center; gap:8px; font-size:15px; }
.sp-head .paw{ fill:var(--coral); }
.sp-head b{ font-weight:800; }
.sp-info{ margin:0; font-size:13px; color:var(--ink2); }
.month-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:9px 14px; }
.mrow{ display:flex; align-items:center; gap:8px; }
.mchk{ display:flex; align-items:center; gap:9px; font-size:14px; font-weight:600; color:var(--ink); cursor:pointer; flex:1; min-width:0; position:relative; }
.mchk input{ position:absolute; opacity:0; width:0; height:0; }
.mbox{ width:21px; height:21px; border:1.6px solid var(--line2); border-radius:6px; background:#fff; display:flex; align-items:center; justify-content:center; color:#fff; flex:none; transition:background .14s, border-color .14s; }
.mbox .ic{ width:13px; height:13px; opacity:0; transition:opacity .14s; }
.mchk input:checked ~ .mbox{ background:var(--coral); border-color:var(--coral); }
.mchk input:checked ~ .mbox .ic{ opacity:1; }
.mday{ width:56px; flex:none; font-family:var(--f); font-weight:700; font-size:13.5px; color:var(--ink); border:1.5px solid var(--line2); border-radius:8px; padding:5px 7px; background:#fff; display:none; }
.mday:focus{ outline:none; border-color:var(--coral); box-shadow:0 0 0 3px var(--coral-50); }
.mrow.checked .mday{ display:block; }
.sp-prev{ border-top:1px solid var(--coral-100); padding-top:12px; }
.sp-prev .flab{ display:block; margin-bottom:4px; }
.sp-prev-txt{ margin:0; font-size:13.5px; color:var(--ink2); font-weight:600; }
@media (max-width:780px){ .month-grid{ grid-template-columns:repeat(2,1fr); } }

/* ---------- language step ---------- */
.lang-pick{ border:1.5px solid var(--line); border-radius:var(--r); padding:14px; display:flex; flex-direction:column; gap:12px; background:var(--coral-50); }
.lp-row{ display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.lp-row .flab{ min-width:120px; }
.tchips{ display:flex; gap:7px; flex-wrap:wrap; }
.tchip{ border:1.6px solid var(--line2); background:#fff; border-radius:999px; padding:6px 14px; font-weight:800; font-size:13px; color:var(--ink2); cursor:pointer; }
.tchip.on{ background:var(--coral); color:#fff; border-color:var(--coral); }
.tchip.orig{ background:#fff; color:var(--ink3); border-style:dashed; cursor:default; }
.tchip:not(.orig):hover{ border-color:var(--coral); }
.tr-mode-soon{ display:flex; gap:8px; flex-wrap:wrap; align-items:center; }

/* ---------- location search dropdown ---------- */
.place-field{ position:relative; }
.place-results{ position:absolute; top:64px; left:0; right:0; z-index:40; background:#fff; border:1.5px solid var(--line2); border-radius:12px; box-shadow:0 12px 30px rgba(0,0,0,.12); overflow:hidden; max-height:260px; overflow-y:auto; }
.place-results[hidden]{ display:none; }
.place-results button{ display:block; width:100%; text-align:left; border:0; background:transparent; padding:9px 12px; cursor:pointer; border-bottom:1px solid var(--line); }
.place-results button:last-child{ border-bottom:0; }
.place-results button:hover{ background:var(--coral-50); }
.place-results b{ font-weight:800; display:block; font-size:13.5px; color:var(--ink); }
.place-results span{ font-size:12px; color:var(--ink2); }
.place-loading{ padding:9px 12px; font-size:12.5px; color:var(--ink3); font-weight:600; }
