/* ===== Fonts (local only) ===== */
@font-face{
font-family: "InterLocal";
src: url("fonts/Inter_18pt-Regular.woff2") format("woff2");
font-weight: 400;
font-style: normal;
font-display: swap;
}
@font-face{
font-family: "InterLocal";
src: url("fonts/Inter_18pt-Bold.woff2") format("woff2");
font-weight: 700;
font-style: normal;
font-display: swap;
}
@font-face{
font-family: "DMMonoLocal";
src: url("fonts/DMMono-Regular.woff2") format("woff2");
font-weight: 400;
font-style: normal;
font-display: swap;
}

:root{
--font-sans: "InterLocal", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
--font-mono: "DMMonoLocal", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;

/* ── Palette (slight adjustment) ── */
--bg: #eaeff8;                          /* slightly cooler than before */
--sheet: rgba(15,23,42,.07);            /* slightly lighter */
--sheetBorder: rgba(15,23,42,.10);
--tile: rgba(255,255,255,.95);          /* tiles slightly whiter/clearer */
--weekendWash: rgba(99,102,241,.05);    /* weekend tint more subtle */
--text: rgba(15,23,42,.90);
--muted: rgba(15,23,42,.50);
--violet: #6d28d9;                      /* one tick more saturated */

--s0: 210, 214, 222;
--s1: 52, 199, 110;                     /* greener, fresher */
--s2: 229, 72,  77;                     /* slightly softer than 235,85,85 */
--s3: 245, 158,  11;                    /* Amber instead of Orange */

--radius: 18px;                         /* slightly larger radius */
--dateH: 34px;
--weekGap: 10px;                        /* slightly more compact */
--stripH: 14px;
--tileH: 104px;
}

*{ box-sizing:border-box; }
html, body{ height:100%; }

body{
margin:0;
font-family: var(--font-sans);
color: var(--text);
background: none;
overflow-x:hidden;
position: relative;
}

/* ── Background gradient: slightly warmer & calmer ── */
body::before{
content:"";
position: fixed;
inset: 0;
z-index: -1;
pointer-events: none;

background:
radial-gradient(860px 380px at 12% -4%, rgba(99,102,241,.09), transparent 58%),
radial-gradient(800px 360px at 88%  2%, rgba(109,40,217,.07), transparent 58%),
linear-gradient(170deg, var(--bg) 0%, #dde5f5 100%);
}

a{ color: inherit; text-decoration: none; }

.app{
min-height:100%;
display:flex;
flex-direction:column;
gap:12px;
padding-bottom: 10px;
}

/* ── Topbar ── */
.topbar{
position:sticky;
top:0;
z-index:50;
-webkit-backdrop-filter: blur(14px) saturate(1.4);   /* stronger blur */
backdrop-filter: blur(14px) saturate(1.4);   /* stronger blur */
background: rgba(255,255,255,.80);
border-bottom: 1px solid rgba(15,23,42,.09);
/* soft shadow instead of hard line */
box-shadow: 0 1px 12px rgba(15,23,42,.06);
}

.topbarGrid{
--stripW: 56px;

position: relative;

display:grid;
grid-template-columns: var(--stripW) 1fr auto;
grid-template-rows: auto;
grid-template-areas:
"home brand who";
align-items:center;

column-gap: 0;

padding: 10px 0;

max-width:1200px;
margin:0 auto;
min-height: 48px;

background:
linear-gradient(90deg,
rgba(15,23,42,.10) 0,
rgba(15,23,42,.10) var(--stripW),
transparent var(--stripW),
transparent 100%
);
}

.topbarGrid::before{
content:"";
position:absolute;
top:0; bottom:0;
left: var(--stripW);
width:1px;
background: rgba(15,23,42,.09);
pointer-events:none;
}
.topbarGrid::after{ content:none; }

.homeStrip{
grid-area: home;

width: var(--stripW);
height: calc(100% + 20px);
margin: -10px 0;
padding: 0;

border: 0;
border-radius: 0;
background: transparent;
box-shadow: none;

display:flex;
align-items:center;
justify-content:center;

cursor:pointer;
transition: background .15s ease;
}
.homeStrip:hover{ background: rgba(15,23,42,.04); }
.homeStrip:active{ filter: brightness(.96); }

.homeChevron{
font-size: 28px;
line-height: 1;
font-weight: 900;
color: rgba(15,23,42,.65);
transform: translateX(-1px) scaleY(1.55);
transform-origin: center;
transition: color .12s ease;
}
.homeStrip:hover .homeChevron{ color: rgba(15,23,42,.85); }

.brandCenter,
.whoDisplay{
padding: 0 12px;
}

.brandCenter{
grid-area: brand;

display: flex;
align-items: center;
gap: 6px;

font-weight: 950;
letter-spacing: .3px;
opacity: .82;
font-size: 17px;

max-width: 100%;
overflow: hidden;

text-align: center;
justify-self: center;
}

.brandCenter > span {
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
min-width: 0;
}

.topbar-logo {
flex-shrink: 0;
display: block;
}

.whoDisplay{
grid-area: who;

display:flex;
align-items:center;
gap:6px;

background: rgba(109,40,217,.10);
border: 1.5px solid rgba(109,40,217,.22);
border-radius: 999px;
padding: 4px 5px 4px 12px;
margin-right: 4px;
}

#whoName,
#demoWhoName{
font-size: 15px;
font-weight: 900;
color: var(--violet);
max-width: min(180px, 36vw);
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
letter-spacing: .15px;
}

.whoSwitchBtn{
border: none;
background: var(--violet);
border-radius: 999px;
padding: 5px 9px;
font-size: 15px;
line-height: 1;
cursor: pointer;
color: #fff;
transition: background .13s ease, transform .1s ease;
flex-shrink: 0;
}
.whoSwitchBtn:hover{ background: rgba(109,40,217,.82); transform: rotate(15deg); }
.whoSwitchBtn:active{ filter: brightness(.90); }

.topbarInner{ display:none; }

/* ── Formularelemente ── */
select, button, input[type="text"], input[type="password"], input[type="number"]{
appearance:none;
border: 1px solid rgba(15,23,42,.28);   /* etwas weicher */
background: rgba(255,255,255,.94);
color: var(--text);
border-radius: 12px;
padding: 10px 10px;
font-size: 14px;
line-height: 1;
outline:none;
box-shadow: 0 2px 6px rgba(15,23,42,.05), 0 1px 2px rgba(15,23,42,.04);
transition: border-color .12s ease, box-shadow .12s ease;
}
select:focus, input[type="text"]:focus, input[type="password"]:focus, input[type="number"]:focus{
border-color: rgba(109,40,217,.45);
box-shadow: 0 0 0 3px rgba(109,40,217,.10), 0 2px 6px rgba(15,23,42,.05);
}
select{
padding-right:34px;
background-image:
linear-gradient(45deg, transparent 50%, rgba(15,23,42,.50) 50%),
linear-gradient(135deg, rgba(15,23,42,.50) 50%, transparent 50%);
background-position: calc(100% - 18px) 50%, calc(100% - 12px) 50%;
background-size: 6px 6px;
background-repeat:no-repeat;
}
button{
cursor:pointer;
font-weight: 800;
touch-action: manipulation;
-webkit-tap-highlight-color: transparent;
transition: filter .10s ease, transform .08s ease, box-shadow .10s ease;
}
button:hover:not(:disabled){ filter: brightness(1.03); box-shadow: 0 4px 10px rgba(15,23,42,.10); }
button:active{ transform: translateY(1px); box-shadow: none; }
button:disabled{ cursor:not-allowed; opacity:.50; box-shadow:none; }

/* ── Layout ── */
.content{
width: 100%;
max-width: 680px;
margin: 0 auto;
padding: 0 12px;
display:flex;
flex-direction:column;
gap:14px;
padding-bottom: 86px;
}

.content > .upcoming:first-child{ margin-top: 12px; }

.landing{
width: 100%;
max-width: 680px;
margin: 18px auto 0 auto;
padding: 0 12px 80px 12px;
display:flex;
flex-direction:column;
gap: 12px;
}

/* ── Hero / Cards ── */
.hero{
background: rgba(255,255,255,.80);
border: 1px solid rgba(15,23,42,.30);
border-radius: var(--radius);
padding: 16px;
box-shadow: 0 8px 28px rgba(15,23,42,.08), 0 2px 6px rgba(15,23,42,.04);
}
.heroTitle{ font-size: 18px; font-weight: 950; letter-spacing:.2px; margin: 0 0 6px 0; }
.heroSub{ font-size: 12px; color: var(--muted); margin: 0; line-height: 1.45; }

.card{
background: rgba(255,255,255,.80);
border: 1px solid rgba(15,23,42,.28);
border-radius: var(--radius);
padding: 14px;
box-shadow: 0 6px 18px rgba(15,23,42,.06), 0 2px 5px rgba(15,23,42,.04);
transition: box-shadow .15s ease;
}
.card:hover{ box-shadow: 0 10px 26px rgba(15,23,42,.09), 0 2px 6px rgba(15,23,42,.05); }

.cardHead{ font-size: 11px; font-weight: 950; letter-spacing:.4px; opacity:.70; margin: 0 0 10px 0; text-transform: uppercase; }

.cardHeadRow{
display:flex;
align-items:center;
justify-content:flex-start;
gap:10px;
}

.xBtn{
width: 22px;
height: 22px;
padding: 0;
border-radius: 8px;
border: 1px solid rgba(220,38,38,.30);
background: rgba(220,38,38,.08);
color: rgba(185,28,28,.95);
font-weight: 950;
line-height: 1;
box-shadow: none;
display:inline-flex;
align-items:center;
justify-content:center;
transition: background .12s ease;
}
.xBtn:hover{ background: rgba(220,38,38,.16); filter: none; box-shadow: none; }
.xBtn:active{ transform: translateY(1px); }

.grid2{ display:grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.row{ display:flex; gap: 8px; align-items:center; flex-wrap: wrap; }
.miniBtn{
padding: 8px 12px;
font-size: 12px;
border-radius: 10px;
box-shadow: none;
font-weight: 850;
white-space:nowrap;
}
.hint{ font-size: 11px; color: var(--muted); margin-top: 6px; line-height: 1.45; }
.small{ font-size: 12px; color: var(--muted); }
.okBox{
margin-top: 10px;
padding: 12px;
border-radius: 14px;
border: 1px solid rgba(109,40,217,.15);   /* leicht violetter Rand */
background: rgba(109,40,217,.04);
display:none;
gap: 8px;
flex-direction: column;
}
.urlBox{
font-family: var(--font-mono);
font-size: 12px;
background: rgba(255,255,255,.90);
border: 1px solid rgba(15,23,42,.12);
border-radius: 10px;
padding: 8px 10px;
overflow:auto;
white-space:nowrap;
}

/* ── Upcoming / Notes ── */
.upcoming{
background: rgba(255,255,255,.74);
border: 1px solid rgba(15,23,42,.09);
border-radius: var(--radius);
padding: 6px 8px;
box-shadow: 0 4px 14px rgba(15,23,42,.05);
}
.upToggle{
width: 100%;
padding: 6px 8px;
font-size: 12px;
border-radius: 12px;
box-shadow: none;
display:flex;
justify-content:space-between;
align-items:center;
border-color: transparent;             /* dezenter im Card-Kontext */
background: transparent;
}
.upToggle:hover{ background: rgba(15,23,42,.03); box-shadow: none; }
.upToggleLeft{ display:flex; gap:8px; align-items:center; min-width: 0; }
#upCount{ opacity:.65; font-weight:900; }
#upChevron{ opacity:.60; font-weight:950; transition: transform .18s ease; }
.upList{ margin-top: 6px; display:flex; flex-direction:column; gap: 4px; }
.upRow{ display:grid; grid-template-columns: 78px minmax(0, 1fr) 34px; gap: 6px; align-items:center; }
.upDate{ font-size: 11px; font-weight: 800; color: rgba(15,23,42,.75); white-space: nowrap; }
.upRow input[type="text"]{
width: 100%;
min-width: 0;
font-size: 12px;
padding: 6px 7px;
border-radius: 10px;
box-shadow:none;
background: rgba(255,255,255,.92);
border: 1px solid rgba(15,23,42,.13);
}
.upRow button{
width: 34px;
height: 26px;
padding: 0;
font-size: 14px;
font-weight: 950;
border-radius: 10px;
box-shadow:none;
display:flex;
align-items:center;
justify-content:center;
}
.emptyNote{ font-size: 11px; color: var(--muted); margin-top: 6px; }

#notesBox .upToggle{ margin: 0; }
#notesBody{ margin-top: 6px; display:flex; flex-direction:column; gap: 6px; }
.notesTopRow{
display:flex;
align-items:center;
justify-content:space-between;
gap: 8px;
}
.notesCount{
font-size: 11px;
font-weight: 850;
color: rgba(15,23,42,.68);
}
.notesText{
width: 100%;
min-height: 120px;
resize: vertical;
border: 1px solid rgba(15,23,42,.13);
background: rgba(255,255,255,.92);
color: var(--text);
border-radius: 12px;
padding: 10px 10px;
font-size: 13px;
line-height: 1.45;
box-shadow: none;
outline: none;
transition: border-color .12s ease;
}
.notesText:focus{
border-color: rgba(109,40,217,.40);
box-shadow: 0 0 0 3px rgba(109,40,217,.09);
}
#notesCountMini{ opacity:.65; font-weight:900; }

/* ── Month / Calendar ── */
.monthWrap{
background: var(--sheet);
border: 1px solid var(--sheetBorder);
border-radius: var(--radius);
padding: 14px;
box-shadow: 0 12px 30px rgba(15,23,42,.09);
}
#months > .monthWrap + .monthWrap{ margin-top: 10px; }

.monthHeader{
display:flex;
align-items:baseline;
justify-content:space-between;
gap:12px;
margin-bottom:10px;
}
.monthTitle{ font-size:17px; font-weight: 950; letter-spacing:.3px; }
.monthMeta{ font-size:11px; color: var(--muted); }

.weeks{ display:flex; flex-direction:column; gap: var(--weekGap); }
.weekRow{
display:grid;
grid-template-columns: repeat(7, minmax(0, 1fr));
gap: 0;
border-radius: 14px;               /* etwas runder */
overflow:hidden;
border: 1px solid rgba(15,23,42,.10);
background: rgba(255,255,255,.16);
box-shadow: 0 2px 6px rgba(15,23,42,.04); /* minimal shadow per row */
}

.day, .blank, .dayHead, .dateSub{ min-width: 0; }
.dateSub{ overflow: hidden; white-space: nowrap; }

.blank{
min-height: var(--tileH);
background: transparent;
border-right: 1px solid rgba(15,23,42,.07);
}
.blank:last-child{ border-right:0; }

.day{
min-height: var(--tileH);
display:flex;
flex-direction:column;
cursor:pointer;
user-select:none;
touch-action: manipulation;
-webkit-tap-highlight-color: transparent;
background: var(--tile);
border-right: 1px solid rgba(15,23,42,.07);
position:relative;
transition: background .10s ease;
}
.day:last-child{ border-right:0; }

.day.weekend{
background:
linear-gradient(180deg, var(--tile), var(--tile)),
linear-gradient(180deg, var(--weekendWash), var(--weekendWash));
}
.day:hover{ filter: brightness(1.015); }
.day:active{ filter: brightness(.985); }

body.viewer-mode .day{ cursor: default; }
body.viewer-mode .day:hover{ filter:none; }

/* MARK: violet head gradient + bar top + left + colored number */
.day.marked .dayHead{
  background: linear-gradient(135deg, rgba(124,58,237,.70) 0%, rgba(167,139,250,.58) 100%);
  border-bottom-color: rgba(109,40,217,.35);
}
.day.marked .dayHead .dateNum{
  color: #fff;
}
.day.marked .dayHead .dateSub{
  color: rgba(255,255,255,.75);
}

.dayHead{
  height: var(--dateH);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: clamp(2px, 1vw, 8px);
  padding: 0 clamp(3px, 1.5vw, 10px);
  border-bottom: 1px solid rgba(15,23,42,.08);
  background: rgba(15,23,42,.02);
  position: relative;
}
.dayHead .dateNum{ font-weight: 950; font-size: clamp(14px, 2.3vw, 17px); line-height: 1; }
.dayHead .dateSub{ font-size: clamp(7px, 1.5vw, 11px); color: var(--muted); font-weight: 350; }

/* TODAY: clearly visible inset border (top/left/right), no fill */
.day.today .dayHead{
  background: rgba(15,23,42,.02);
  border-bottom-color: rgba(15,23,42,.10);
  box-shadow:
    inset 0 3px 0 rgba(15,23,42,.55),     /* top */
    inset 3px 0 0 rgba(15,23,42,.55),     /* left */
    inset -3px 0 0 rgba(15,23,42,.55),    /* right */
    inset 0 0 0 1px rgba(15,23,42,.18);   /* subtle extra border */
}

/* marked + today: marked stays violet, today-inset keeps usual dark color */
.day.today.marked .dayHead{
  background: linear-gradient(135deg, rgba(124,58,237,.70) 0%, rgba(167,139,250,.58) 100%);
  border-bottom-color: rgba(109,40,217,.35);
  box-shadow:
    inset 0 3px 0 rgba(15,23,42,.55),
    inset 3px 0 0 rgba(15,23,42,.55),
    inset -3px 0 0 rgba(15,23,42,.55),
    inset 0 0 0 1px rgba(15,23,42,.18);
}

/* OPTIONAL: if you additionally want a violet overlay border on marked+today */
/*
.day.today.marked .dayHead::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius: 8px;
  box-shadow: inset 0 0 0 3px rgba(109,40,217,.90);
  pointer-events:none;
}
*/
.stripes{ display:flex; flex-direction:column; flex:1; }
.stripe{
height: var(--stripH);
position:relative;
display:flex;
align-items:center;
padding: 0 10px;
border-bottom: 1px solid rgba(15,23,42,.05);
overflow:hidden;
}
.stripe:last-child{ border-bottom:0; }
.stripe::before{
content:"";
position:absolute;
inset:0;
background: rgba(var(--rgb), var(--a, 1));
z-index:0;
}
.stripe > span{
position: relative;
z-index: 1;
font-size: 11px;
font-weight: 300;
color: rgba(15,23,42,.68);
display: block;
width: 100%;
min-width: 0;
white-space: nowrap;
overflow: hidden;
-webkit-mask-image: linear-gradient(to right, black calc(100% - 8px), transparent 100%);
mask-image: linear-gradient(to right, black calc(100% - 8px), transparent 100%);
}

body.member-mode .stripe{ --a: .28; }
body.member-mode .stripe.active{ --a: 1; }
body.group-mode .stripe{ --a: 1; }
body.viewer-mode .stripe{ --a: 1; }

/* ── Bottom Bar ── */
.bottombar{
position: fixed;
left: 0;
right: 0;
bottom: 0;
z-index: 60;
padding: 6px 8px calc(6px + env(safe-area-inset-bottom));
background: rgba(255,255,255,.85);
border-top: 1px solid rgba(15,23,42,.09);
-webkit-backdrop-filter: blur(14px) saturate(1.3);
backdrop-filter: blur(14px) saturate(1.3);
box-shadow: 0 -2px 14px rgba(15,23,42,.06);
}
.bottombarInner{
max-width: 1200px;
margin: 0 auto;
display:flex;
flex-direction:column;
gap: 6px;
align-items:center;
justify-content:center;
}
.barRow{
display:flex;
gap: 8px;
align-items:center;
justify-content:center;
width: 100%;
flex-wrap: nowrap;
}
.barRow button{
box-sizing: border-box;
height: 28px;                          /* slightly taller */
padding: 0 10px;
display: inline-flex;
align-items: center;
justify-content: center;
line-height: 1;
font-size: 12px;
font-weight: 850;
border-radius: 10px;
box-shadow:none;
}
#homeBtn{
width: 30px;
padding: 0;
}
#homeBtn svg{ display:block; width:12px; height:12px; }

/* ── Modals ── */
.modalOverlay{
position: fixed;
inset: 0;
background: rgba(15,23,42,.50);
display:none;
align-items:center;
justify-content:center;
z-index: 1000;
padding: 14px;
}
.modal{
width: min(760px, 100%);
background: rgba(255,255,255,.95);
border: 1px solid rgba(15,23,42,.10);
border-radius: var(--radius);
box-shadow: 0 24px 56px rgba(15,23,42,.20), 0 4px 12px rgba(15,23,42,.08);
padding: 16px;
overflow: hidden;
}
.adminModal{
max-height: min(92vh, 820px);
overflow-y: auto;
}
.adminModal .modalTitle{
margin: -16px -16px 18px -16px;
padding: 20px 20px 16px;
font-size: 18px;
font-weight: 950;
letter-spacing: .35px;
color: var(--violet);
background: linear-gradient(135deg, rgba(109,40,217,.10) 0%, rgba(99,102,241,.06) 100%);
border-bottom: 1.5px solid rgba(109,40,217,.14);
border-radius: calc(var(--radius) - 1px) calc(var(--radius) - 1px) 0 0;
text-align: center;
}
.modalTitle{ font-size: 16px; font-weight: 950; margin: 0 0 6px 0; letter-spacing: .2px; }
.modalSub{ font-size: 12px; color: var(--muted); margin: 0 0 10px 0; line-height: 1.45; }
.formError{ color: #e53e3e; font-size: 12px; margin-top: 8px; }

/* ── Landing page modals ── */
.lpModal{
width: min(520px, 100%);
max-height: min(90vh, 680px);
overflow-y: auto;
}

/* Styled header for lpModal and whoPickerModal */
.lpModal .modalTitle,
.whoPickerModal .modalTitle {
margin: -16px -16px 18px -16px;
padding: 20px 20px 16px;
font-size: 18px;
font-weight: 950;
letter-spacing: .35px;
color: var(--violet);
background: linear-gradient(135deg, rgba(109,40,217,.10) 0%, rgba(99,102,241,.06) 100%);
border-bottom: 1.5px solid rgba(109,40,217,.14);
border-radius: calc(var(--radius) - 1px) calc(var(--radius) - 1px) 0 0;
text-align: center;
}

/* Section headers in lpModal */
.lpModal .cardHead {
color: var(--violet);
opacity: 1;
padding-left: 9px;
border-left: 3px solid var(--violet);
margin-bottom: 8px;
}

/* ── Who Picker ── */
.whoPickerModal{
width: min(420px, 100%);
}
.whoPickerList{
display: flex;
flex-direction: column;
gap: 8px;
max-height: min(70vh, 480px);
overflow-y: auto;
padding: 2px 2px 2px 0;
}
.whoPickerBtn{
width: 100%;
text-align: center;
padding: 13px 16px;
font-size: 15px;
font-weight: 700;
border: 1px solid rgba(15,23,42,.10);
border-left: 3px solid rgba(109,40,217,.20);
border-radius: 12px;
background: rgba(15,23,42,.03);
color: var(--text);
cursor: pointer;
transition: background .13s ease, border-color .13s ease, transform .1s ease;
letter-spacing: .1px;
}
.whoPickerBtn:hover{ background: rgba(109,40,217,.07); border-left-color: rgba(109,40,217,.55); border-color: rgba(109,40,217,.20); transform: translateX(2px); }
.whoPickerBtn:active{ filter: brightness(.95); transform: translateX(0); }
.whoPickerBtn.whoViewer{
color: var(--muted);
font-weight: 600;
font-size: 14px;
border-left-color: rgba(15,23,42,.12);
}
.whoPickerBtn.whoViewer:hover{ border-left-color: rgba(15,23,42,.30); }
.whoPickerBtn.whoGroup{
color: var(--violet);
border-left-color: var(--violet);
}

/* ── Admin ── */
.adminList{
display:flex;
flex-direction:column;
gap: 8px;
max-height: min(60vh, 540px);
overflow-y: auto;
overflow-x: hidden;
padding-right: 2px;
}

/* ── Change-password accordion ── */
.changePassAccordion{
  background: rgba(255,255,255,.80);
  border: 1px solid rgba(15,23,42,.10);
  border-radius: var(--radius);
  box-shadow: 0 4px 10px rgba(15,23,42,.05);
}
.changePassToggle{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 10px 14px;
  cursor: pointer;
  list-style: none;
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .4px;
  text-transform: uppercase;
  opacity: .70;
  border-radius: var(--radius);
  transition: background .12s ease;
}
.changePassToggle::-webkit-details-marker{ display: none; }
.changePassToggle:hover{ background: rgba(15,23,42,.03); }
.changePassChevron{
  width: 12px;
  height: 12px;
  flex-shrink: 0;
  color: rgba(15,23,42,.50);
  transition: transform .18s ease;
}
details[open] > .changePassToggle .changePassChevron{
  transform: rotate(180deg);
}
.changePassBody{
  padding: 0 14px 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.adminEntry{ display:flex; flex-direction:column; }
.adminRow{
display:grid;
grid-template-columns: 36px minmax(0,1fr) 62px 36px;
gap: 8px;
align-items:center;
background: rgba(15,23,42,.025);
border: 1px solid rgba(15,23,42,.07);
border-radius: 12px;
padding: 8px;
transition: background .12s ease, border-radius .12s ease;
}
.adminEntry.menuOpen .adminRow{ border-radius: 12px 12px 0 0; }
.adminRow:hover{ background: rgba(15,23,42,.045); }
.adminRow.inactive{
opacity: .50;
filter: grayscale(.40);
background: rgba(15,23,42,.015);
}
.adminKey{ font-weight: 950; font-size: 12px; color: rgba(15,23,42,.60); text-align:center; }
.adminGroupLabel{ font-weight: 900; font-size: 13px; color: rgba(15,23,42,.78); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; min-width:0; }
.adminRow input[type="text"]{
box-shadow:none;
padding: 7px 9px;
border-radius: 10px;
font-size: 13px;
width: 100%;
min-width: 0;
}
.adminBtns{ display:flex; gap: 4px; justify-content:center; align-items:center; }
.adminBtns button{
width: 28px;
height: 28px;
padding: 0;
border-radius: 8px;
box-shadow:none;
font-weight: 950;
font-size: 13px;
flex-shrink: 0;
}
.adminTrash{
width: 34px;
height: 34px;
padding: 0;
border-radius: 10px;
box-shadow:none;
border: 1px solid rgba(220,38,38,.22);
color: rgba(153,27,27,.80);
background: transparent;
cursor: pointer;
display: flex;
align-items: center;
justify-content: center;
flex-shrink: 0;
transition: background .12s ease;
}
.adminTrash:hover{ background: rgba(220,38,38,.09); }
.trashMenu{
display: none;
flex-direction: row;
gap: 8px;
flex-wrap: wrap;
padding: 8px;
border: 1px solid rgba(220,38,38,.12);
border-top: none;
border-radius: 0 0 12px 12px;
background: rgba(255,250,250,.97);
}
.adminEntry.menuOpen .trashMenu{ display: flex; }
.trashMenuBtn{
flex: 1;
min-width: 110px;
padding: 7px 10px;
border-radius: 8px;
font-size: 12px;
font-weight: 750;
cursor: pointer;
border: 1px solid rgba(220,38,38,.22);
color: rgba(153,27,27,.95);
background: rgba(220,38,38,.04);
white-space: nowrap;
text-align: center;
transition: background .12s ease;
}
.trashMenuBtn:hover{ background: rgba(220,38,38,.12); }
.trashMenuBtn.secondary{
border-color: rgba(15,23,42,.14);
color: rgba(15,23,42,.70);
background: rgba(15,23,42,.03);
}
.trashMenuBtn.secondary:hover{ background: rgba(15,23,42,.08); }
.adminAct{ display:flex; justify-content:flex-end; gap: 8px; margin-top: 10px; flex-wrap: wrap; align-items:center; }
.chip{ font-size: 11px; color: var(--muted); }

/* ── Confirm Dialog ── */
.confirmModal{
  width: min(400px, 100%);
  text-align: center;
  padding: 28px 24px 22px;
}
.confirmIconWrap{
  display: flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  margin: 0 auto 14px;
  background: rgba(220,38,38,.10);
  color: #dc2626;
}
.confirmIconWrap.neutral{
  background: rgba(109,40,217,.10);
  color: var(--violet);
}
.confirmTitle{
  font-size: 16px;
  font-weight: 950;
  letter-spacing: .2px;
  color: var(--text);
  margin-bottom: 8px;
}
.confirmMsg{
  font-size: 13px;
  color: var(--muted);
  line-height: 1.5;
  margin-bottom: 22px;
}
.confirmBtns{
  display: flex;
  gap: 10px;
  justify-content: center;
}
.confirmBtnCancel{
  background: rgba(15,23,42,.06);
  color: var(--text);
  border: 1px solid rgba(15,23,42,.12);
  min-width: 110px;
}
.confirmBtnCancel:hover:not(:disabled){ filter: brightness(.97); }
.confirmBtnOk{
  background: #dc2626;
  color: #fff;
  border: none;
  min-width: 110px;
}
.confirmBtnOk:hover:not(:disabled){ filter: brightness(1.08); }
.confirmBtnOk.confirmBtnNeutral{
  background: var(--violet);
}

/* ── Toast ── */
.toast{
position:fixed;
left:50%;
bottom: calc(86px + env(safe-area-inset-bottom));
transform:translateX(-50%);
background: rgba(15,23,42,.90);
color: rgba(255,255,255,.92);
border: 1px solid rgba(255,255,255,.12);
border-radius:14px;
padding:9px 14px;
font-size:12px;
font-weight: 600;
letter-spacing: .2px;
box-shadow: 0 12px 28px rgba(15,23,42,.22);
opacity:0;
pointer-events:none;
transition: opacity .18s ease, transform .18s ease;
max-width:min(920px, calc(100vw - 24px));
white-space:nowrap;
overflow:hidden;
text-overflow:ellipsis;
z-index:1100;
}
.toast.show{ opacity:1; transform: translateX(-50%) translateY(-2px); }

/* Touch: kein Hover-Flicker */
@media (hover: none){
.day:hover{ filter:none; }
.card:hover{ box-shadow: 0 6px 18px rgba(15,23,42,.06); }
.adminRow:hover{ background: rgba(15,23,42,.025); }
}

/* ── Mobile Responsive ── */
@media (max-width: 720px){
.grid2{ grid-template-columns: 1fr; }
.adminRow{ grid-template-columns: 32px minmax(0,1fr) 58px 34px; }
.content{ padding-bottom: 96px; }
.bottombarInner{ justify-content: space-between; }
}

@media (max-width: 420px){
:root{ --dateH: 28px; --stripH: 12px; --weekGap: 7px; }

.adminRow{ grid-template-columns: 30px minmax(0,1fr) 54px 32px; }
.barRow{ gap: 6px; }
.barRow button{ padding: 0 7px; }

.monthWrap{ padding: 10px; }
.stripe{ padding: 0 4px; }

.stripe > span{ font-size: 10px; font-weight: 350; }
}

@media (max-width: 360px){
:root{ --dateH: 24px; --stripH: 11px; --weekGap: 6px; }

.monthWrap{ padding: 8px; }
.stripe{ padding: 0 3px; }
}

/* grid2Tight bleibt immer 2-spaltig */
.grid2Tight{ grid-template-columns: 1fr 1fr; }
@media (max-width: 720px){
.grid2Tight{ grid-template-columns: 1fr 1fr; }
}

.landing #createPass,
.landing #createPass2{
min-width: 0;
}

/* ============================================================
   LANDING PAGE V2
   All selectors use lp- prefix to avoid conflicts.
   Calendar preview reuses real app CSS classes unchanged.
   ============================================================ */

html {
  scroll-behavior: smooth;
  scroll-padding-top: 72px;
}

/* Override base landing layout for v2 full-width design */
.landing.landing-v2 {
  max-width: 100%;
  margin: 0;
  padding: 0;
  gap: 0;
}

/* ── Navigation ── */
.lp-nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 50;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .875rem 1.5rem;
  -webkit-backdrop-filter: blur(14px) saturate(1.4);
  backdrop-filter: blur(14px) saturate(1.4);
  background: rgba(255,255,255,.85);
  border-bottom: 1px solid rgba(15,23,42,.09);
  box-shadow: 0 1px 12px rgba(15,23,42,.06);
}
.lp-nav-logo {
  display: flex;
  align-items: center;
  gap: .5rem;
}
.lp-nav-logo-icon {
  width: 2rem; height: 2rem;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}
.lp-nav-logo-text { font-size: 1.1rem; font-weight: 950; letter-spacing: .3px; }
.lp-nav-links { display: flex; align-items: center; gap: 1.5rem; }
.lp-nav-links a { font-size: .875rem; font-weight: 700; color: var(--muted); transition: color .15s; }
.lp-nav-links a:hover { color: var(--text); }
.lp-nav-actions { display: flex; align-items: center; gap: .75rem; }

/* ── Landing Buttons ── */
.lp-btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: .4rem;
  font-family: var(--font-sans);
  font-weight: 800; font-size: .9rem;
  border: none; cursor: pointer;
  border-radius: 999px;
  padding: .6rem 1.3rem;
  transition: filter .12s, transform .1s, box-shadow .12s;
  text-decoration: none;
}
.lp-btn:hover { filter: brightness(1.05); box-shadow: 0 4px 14px rgba(15,23,42,.12); }
.lp-btn:active { transform: translateY(1px); }
.lp-btn-primary { background: var(--violet); color: #fff; }
.lp-btn-outline {
  background: rgba(255,255,255,.90);
  color: var(--text);
  border: 1px solid rgba(15,23,42,.18) !important;
}
.lp-btn-lg { font-size: 1.05rem; padding: .9rem 2rem; }

/* ── Hero ── */
.lp-hero {
  padding: 8rem 1.5rem 4rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  max-width: 1280px;
  margin: 0 auto;
  width: 100%;
  box-sizing: border-box;
}
.lp-hero-badge {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .4rem .9rem;
  border-radius: 999px;
  background: rgba(109,40,217,.08);
  color: var(--violet);
  font-size: .875rem;
  font-weight: 700;
  margin-bottom: 2rem;
}
.lp-badge-dot-wrap { position: relative; width: .5rem; height: .5rem; }
.lp-badge-dot, .lp-badge-dot-ping {
  position: absolute; inset: 0;
  border-radius: 50%;
  background: var(--violet);
}
@keyframes lp-ping { 75%, 100% { transform: scale(2); opacity: 0; } }
.lp-badge-dot-ping { opacity: .7; animation: lp-ping 1.4s cubic-bezier(0,0,.2,1) infinite; }
.lp-h1 {
  font-size: clamp(2.5rem, 6.5vw, 5rem);
  font-weight: 950;
  letter-spacing: -.04em;
  line-height: 1.08;
  max-width: 820px;
  margin: 0 0 1.5rem 0;
  color: var(--text);
}

.lp-hero-sub {
  font-size: clamp(2rem, 4.4vw, 2.8rem);
  font-weight: 950;
  color: var(--text);
  max-width: 820px;
  margin: 0 0 1rem 0;
  line-height: 1.28;
}

.lp-hero-sub-minor {
  font-size: clamp(1.6rem, 3.2vw, 2rem);
  color: var(--muted);
  max-width: 820px;
  margin: 0 0 1rem 0;
  line-height: 1.4;
}
.lp-hero-cta {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: center;
  margin-top: 2.5rem;
  margin-bottom: 3.5rem;
}

/* ── Mockup Panel ── */
.lp-mockup-wrap {
  width: 100%;
  max-width: 960px;
  margin: 0 auto;
  position: relative;
}
.lp-mockup-wrap::before {
  content: "";
  position: absolute;
  inset: -40px;
  background: rgba(109,40,217,.15);
  filter: blur(80px);
  border-radius: 50%;
  z-index: -1;
  pointer-events: none;
}
.lp-mockup-wrap::after {
  content: "";
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 30%;
  background: linear-gradient(to top, #eaeff8, transparent);
  z-index: 5;
  pointer-events: none;
}
@media (max-width: 900px) {
  .lp-mockup-wrap::after { display: none; }
}
.lp-mockup-card {
  border-radius: 2rem;
  border: 1px solid rgba(15,23,42,.12);
  background: rgba(255,255,255,.70);
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  padding: 1.25rem;
  box-shadow: 0 24px 60px rgba(15,23,42,.10), 0 4px 12px rgba(15,23,42,.06);
  position: relative;
  overflow: hidden;
  display: flex;
  gap: 1.25rem;
  align-items: stretch;
}
.lp-mockup-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, var(--violet), rgba(109,40,217,.3), transparent);
}

/* ── Group List ── */
.lp-group-list {
  width: 195px;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  gap: .6rem;
  justify-content: center;
}
.lp-group-list-label {
  font-size: .7rem;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--muted);
  margin-bottom: .15rem;
}
.lp-group-item {
  display: flex;
  align-items: center;
  gap: .65rem;
  padding: .6rem .7rem;
  border-radius: 14px;
  border: 1px solid transparent;
}
.lp-group-item.active { background: rgba(109,40,217,.07); border-color: rgba(109,40,217,.15); }
.lp-group-item:not(.active) { background: rgba(15,23,42,.02); }
.lp-group-icon {
  width: 2.1rem; height: 2.1rem;
  border-radius: .6rem;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem;
  flex-shrink: 0;
}
.lp-group-icon.indigo { background: rgba(99,102,241,.12); }
.lp-group-icon.orange { background: rgba(249,115,22,.12); }
.lp-group-icon.purple { background: rgba(168,85,247,.12); }
.lp-group-name { font-size: .82rem; font-weight: 950; }
.lp-group-meta {
  font-size: .7rem; color: var(--muted);
  display: flex; align-items: center; gap: .3rem;
}
.lp-dot { width: .4rem; height: .4rem; border-radius: 50%; }
.lp-dot-green { background: #34c96e; }
.lp-dot-amber { background: #f59e0b; }
.lp-dot-muted { background: rgba(15,23,42,.20); }

/* ── Feature list (replaces group-selector in mockup) ── */
.lp-feature-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: .5rem;
  align-items: center;
}
.lp-feature-list li {
  font-size: .78rem;
  font-weight: 600;
  letter-spacing: .04em;
  color: var(--violet);
  text-align: center;
  padding: .35rem .85rem;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(109,40,217,.09), rgba(99,102,241,.05));
  width: 100%;
  box-sizing: border-box;
}

/* ── App Panel (calendar preview) ── */
.lp-app-panel {
  flex: 1;
  border-radius: 14px;
  overflow: hidden;
  min-width: 0;
  background: var(--bg);
  box-shadow: inset 0 0 0 1px rgba(15,23,42,.08);
  display: flex;
  flex-direction: column;
}
/* Make topbar non-sticky inside the mockup */
.lp-app-panel .topbar { position: relative !important; }
.lp-app-panel .topbarGrid { min-height: 40px; padding: 6px 0; }
.lp-cal-wrap {
  flex: 1;
  padding: .6rem .5rem;
  overflow: hidden;
}
.lp-cal-wrap .monthWrap { box-shadow: 0 6px 18px rgba(15,23,42,.07); }
.lp-cal-wrap .stripe { padding: 0 4px; }

/* ── Float Card ── */
.lp-float-card {
  position: absolute;
  bottom: 2.5rem; right: 0.5rem;
  background: #0f172a;
  color: #fff;
  padding: 1.1rem 1.3rem;
  border-radius: 1.2rem;
  box-shadow: 0 20px 50px rgba(15,23,42,.25);
  max-width: 290px;
  display: flex;
  gap: .85rem;
  align-items: flex-start;
  transform: rotate(1.5deg);
  transition: transform .2s ease;
  z-index: 6;
}
.lp-float-card:hover { transform: rotate(0); }
.lp-float-icon {
  width: 3.5rem; height: 3.5rem;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; overflow: hidden;
}
.lp-float-card h3 { font-size: .95rem; font-weight: 950; margin: 0 0 .2rem 0; }
.lp-float-card p { font-size: .75rem; color: rgba(255,255,255,.65); line-height: 1.45; margin: 0; }

/* ── Use Cases ── */
.lp-use-cases {
  background: #0f172a;
  color: #fff;
  padding: 5rem 1.5rem;
}
.lp-use-cases-container { max-width: 1100px; margin: 0 auto; }
.lp-use-cases-header {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
  margin-bottom: 3rem;
}
.lp-use-cases-header h2 {
  font-size: clamp(2rem, 5vw, 3.5rem);
  font-weight: 950;
  letter-spacing: -.03em;
  max-width: 540px;
  margin: 0;
  flex-shrink: 0;
}
.lp-use-cases-right {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  max-width: 420px;
}
.lp-use-cases-header p { font-size: 1rem; color: rgba(255,255,255,.55); line-height: 1.6; margin: 0; }
.lp-use-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.25rem; }
.lp-use-card {
  position: relative;
  border-radius: 1.5rem;
  overflow: hidden;
  min-height: 220px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}
.lp-use-card-band {
  background:
    linear-gradient(5deg, rgba(30,27,75,1) 0%, rgba(55,48,163,.80) 35%, transparent 50%),
    url('images/usecase01.png') center / cover no-repeat;
  background-color: #1e1b4b;
}
.lp-use-card-sports {
  background:
    linear-gradient(5deg, rgba(3,58,30,1) 0%, rgba(6,78,59,.80) 35%, transparent 50%),
    url('images/usecase02.png') center / cover no-repeat;
  background-color: #033a1e;
}
.lp-use-card-game {
  background:
    linear-gradient(5deg, rgba(26,10,10,1) 0%, rgba(127,29,29,.80) 35%, transparent 50%),
    url('images/usecase03.png') center / cover no-repeat;
  background-color: #1a0a0a;
}
.lp-use-card-more {
  background: linear-gradient(135deg, #0f0c29 0%, #1e1b4b 60%, #312e81 100%);
}
.lp-use-card-deco {
  position: absolute;
  top: 1rem; right: 1rem;
  font-size: 4rem;
  opacity: .20;
  line-height: 1;
  pointer-events: none;
  user-select: none;
}
.lp-use-col { display: flex; flex-direction: column; gap: 1.25rem; }
.lp-use-info { padding: 1.5rem 1.5rem 0.75rem; }
.lp-use-tag {
  display: inline-block;
  padding: .2rem .7rem;
  border-radius: 999px;
  background: rgba(109,40,217,.25);
  color: #c4b5fd;
  font-size: .7rem; font-weight: 700;
  margin-bottom: .5rem;
}
.lp-use-info h3 { font-size: 1.5rem; font-weight: 950; margin: 0 0 .35rem 0; }
.lp-use-info p { font-size: .875rem; color: rgba(255,255,255,.70); line-height: 1.5; margin: 0; }
.lp-more-list {
  list-style: none;
  padding: 0;
  margin: .75rem 0 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: repeat(4, auto);
  gap: .5rem .5rem;
}
.lp-more-list li { display: flex; align-items: center; justify-content: center; font-size: .95rem; color: rgba(255,255,255,.75); }
.lp-use-card-more .lp-use-info {
  padding: 1.75rem;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  height: 100%;
}
.lp-use-card-more .lp-use-info h3 { text-align: center; }
.lp-use-card-more .lp-check-icon { color: #6ee7b7; }
.lp-also-list {
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 1.5rem;
  padding: 1.5rem;
  display: flex; flex-direction: column; justify-content: center;
  flex: 1;
}
.lp-also-list h3 { font-size: 1.15rem; font-weight: 950; margin: 0 0 1rem 0; }
.lp-also-list ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .75rem; }
.lp-also-list li { display: flex; align-items: center; gap: .65rem; font-size: .95rem; color: rgba(255,255,255,.65); }
.lp-check-icon { color: #a78bfa; font-size: 1rem; flex-shrink: 0; }
.lp-use-trust {
  margin: 2rem 0 0;
  text-align: center;
  font-size: .95rem;
  color: rgba(255,255,255,.50);
  font-style: italic;
}

/* ── CTA Section ── */
.lp-cta-section { padding: 5rem 1.5rem; }
.lp-cta-box {
  max-width: 860px; margin: 0 auto;
  background: var(--violet);
  border-radius: 2.5rem;
  padding: 3.5rem 2rem;
  text-align: center;
  position: relative; overflow: hidden;
}
.lp-cta-glow-top {
  position: absolute; top: -2rem; right: -2rem;
  width: 14rem; height: 14rem;
  background: rgba(255,255,255,.18);
  filter: blur(48px); border-radius: 50%;
}
.lp-cta-glow-bottom {
  position: absolute; bottom: -2rem; left: -2rem;
  width: 14rem; height: 14rem;
  background: rgba(0,0,0,.10);
  filter: blur(48px); border-radius: 50%;
}
.lp-cta-box h2 {
  font-size: clamp(2.2rem, 5.5vw, 4rem);
  font-weight: 950; letter-spacing: -.04em; line-height: 1.05;
  color: #fff; margin: 0 0 1rem 0;
  position: relative; z-index: 1;
}
.lp-cta-box > p {
  font-size: 1.1rem; color: rgba(255,255,255,.75);
  max-width: 380px; margin: 0 auto 2.25rem;
  position: relative; z-index: 1;
}
.lp-btn-cta {
  display: inline-block;
  background: #0f172a; color: #fff;
  border-radius: 999px;
  padding: .9rem 2.25rem;
  font-size: 1.05rem; font-weight: 800;
  border: none; cursor: pointer;
  position: relative; z-index: 1;
  transition: filter .12s, transform .1s;
  text-decoration: none;
  font-family: var(--font-sans);
}
.lp-btn-cta:hover { filter: brightness(1.15); transform: scale(1.03); }

/* ── Footer ── */
.lp-footer {
  padding: 2.5rem 1.5rem;
  border-top: 1px solid rgba(15,23,42,.10);
  text-align: center;
}
.lp-footer-logo {
  display: flex; align-items: center; justify-content: center;
  gap: .5rem; margin-bottom: .75rem;
  color: var(--muted);
  font-weight: 800; font-size: .95rem;
}
.lp-footer > p { font-size: .875rem; color: var(--muted); margin: 0; }
.lp-footer-legal {
  display: flex; align-items: center; justify-content: center;
  gap: 1.25rem; margin-top: .85rem;
}
.lp-footer-legal a {
  font-size: .8rem; color: var(--muted);
  text-decoration: none;
  transition: color .15s;
}
.lp-footer-legal a:hover { color: var(--violet); }

/* ── Fade-up scroll animation (progressive enhancement) ── */
/* Default: content is visible. JS adds html.lp-js to enable the animation. */
.lp-fade-up { transition: opacity .6s ease, transform .6s ease; }
html.lp-js .lp-fade-up { opacity: 0; transform: translateY(24px); }
html.lp-js .lp-fade-up.lp-visible { opacity: 1; transform: translateY(0); }
.lp-delay-1 { transition-delay: .10s; }
.lp-delay-2 { transition-delay: .20s; }
.lp-delay-3 { transition-delay: .30s; }
.lp-delay-4 { transition-delay: .45s; }

/* ── Landing V2 Responsive ── */
@media (max-width: 900px) {
  .lp-mockup-card { flex-direction: column; }
  .lp-app-panel { order: 1; }
  .lp-group-list { order: 2; width: 100%; flex-direction: column; align-items: center; justify-content: center; gap: .45rem; }
  .lp-group-list-label { display: none; }
  .lp-feature-list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    width: 100%;
    max-width: 420px;
    gap: .5rem;
  }
  .lp-feature-list li { flex: unset; font-size: .75rem; text-align: center; }
  .lp-float-card { display: none; }
}
@media (max-width: 768px) {
  .lp-use-grid { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .lp-hero { padding: 7rem 1rem 2.5rem; }
  .lp-h1 { font-size: 2.4rem; }
  .lp-nav-links { display: none; }
  .lp-hero-cta { flex-direction: column; align-items: stretch; }
  .lp-hero-cta .lp-btn { justify-content: center; }
  .lp-use-cases { padding: 3.5rem 1rem; }
  .lp-feature-list { grid-template-columns: 1fr; max-width: 280px; }
}
@media (max-width: 480px) {
  .lp-nav {
    flex-direction: column;
    align-items: center;
    gap: .5rem;
    padding: .6rem 1rem;
  }
  .lp-nav-actions {
    width: 100%;
    justify-content: center;
  }
  .lp-hero { padding-top: 9rem; }
}
/* ── Demo Calendar Overlay ── */
.demoShell {
  position: fixed;
  inset: 0;
  z-index: 500;
  background: var(--bg);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.demoBanner {
  flex-shrink: 0;
  background: rgba(109, 40, 217, .10);
  border-bottom: 1px solid rgba(109, 40, 217, .18);
  padding: 7px 16px;
  font-size: 12px;
  font-weight: 700;
  color: rgba(109, 40, 217, .88);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.demoBannerClose {
  font-size: 12px;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 8px;
  border: 1px solid rgba(109, 40, 217, .28);
  background: transparent;
  color: rgba(109, 40, 217, .88);
  cursor: pointer;
  flex-shrink: 0;
  white-space: nowrap;
}
.demoBannerClose:hover {
  background: rgba(109, 40, 217, .08);
}
.demoContent {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  padding-bottom: 16px;
}
.demoBottombar {
  flex-shrink: 0;
  padding: 6px 8px calc(6px + env(safe-area-inset-bottom));
  background: rgba(255, 255, 255, .85);
  border-top: 1px solid rgba(15, 23, 42, .09);
  -webkit-backdrop-filter: blur(14px) saturate(1.3);
  backdrop-filter: blur(14px) saturate(1.3);
  box-shadow: 0 -2px 14px rgba(15, 23, 42, .06);
}
.demoBottombar .bottombarInner {
  justify-content: center;
}

/* ── Language Switcher ─────────────────────────────────────────────────── */
.lang-switcher {
  display: flex;
  gap: 3px;
  align-items: center;
}
.lang-select {
  appearance: none;
  -webkit-appearance: none;
  padding: 3px 22px 3px 8px;
  border-radius: 5px;
  border: 1px solid rgba(15, 23, 42, .18);
  background: transparent url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='rgba(15,23,42,.45)'/%3E%3C/svg%3E") no-repeat right 7px center / 8px 5px;
  color: rgba(15, 23, 42, .65);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .04em;
  cursor: pointer;
  line-height: 1.6;
  transition: background-color .15s, color .15s, border-color .15s;
}
.lang-select:hover {
  background-color: rgba(15, 23, 42, .07);
  color: rgba(15, 23, 42, .90);
  border-color: rgba(15, 23, 42, .28);
}
.lang-select:focus {
  outline: 2px solid rgba(15, 23, 42, .25);
  outline-offset: 1px;
}

/* ── Maintenance mode ───────────────────────────────────────────────────── */
.maintenanceShell{
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  padding: 24px 12px;
}
.maintenanceBadge{
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .10em;
  text-transform: uppercase;
  color: rgba(109,40,217,.85);
  background: rgba(109,40,217,.08);
  border: 1px solid rgba(109,40,217,.20);
  padding: 4px 12px;
  border-radius: 999px;
}
.maintenanceTitle{
  font-size: clamp(20px, 4vw, 32px);
  font-weight: 950;
  letter-spacing: .3px;
  text-align: center;
  color: rgba(15,23,42,.88);
}
/* Cards constrained to LP-mockup scale; always 3 columns, never wraps */
.maintenanceDaysFade{
  width: min(480px, 100%);
  overflow: hidden;
  position: relative;
}
.maintenanceDaysFade::before,
.maintenanceDaysFade::after{
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: 40px;
  z-index: 2;
  pointer-events: none;
}
.maintenanceDaysFade::before{
  left: 0;
  background: linear-gradient(to right, var(--bg), rgba(234,239,248,0));
}
.maintenanceDaysFade::after{
  right: 0;
  background: linear-gradient(to left, var(--bg), rgba(234,239,248,0));
}
.maintenanceDays{
  display: grid;
  gap: 6px;
  /* Always 3 columns regardless of screen width */
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.maintenanceDay{
  border-radius: 10px;
  overflow: hidden;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(15,23,42,.10);
  box-shadow: 0 4px 10px rgba(15,23,42,.07);
}
.maintenanceDayHead{
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 4px 6px;
  height: 26px;
  background: rgba(15,23,42,.03);
  border-bottom: 1px solid rgba(15,23,42,.08);
}
.maintenanceDayHead span{
  font-size: 9px;
  color: rgba(15,23,42,.55);
}
.maintenanceDayHead b{
  font-size: clamp(11px, 2.5vw, 14px);
  font-weight: 950;
}
.maintenanceStripe{
  height: 13px;
  padding: 0 4px;
  display: flex;
  align-items: center;
  font-size: 8px;
  font-weight: 700;
  color: rgba(15,23,42,.68);
  background: rgba(var(--rgb), .90);
  border-bottom: 1px solid rgba(15,23,42,.04);
}
.maintenanceStripe:last-child{ border-bottom: 0; }
