/* Alfathusain — frameless, warm-dark, modern */
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:#0c0a09}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:#2a241f;border-radius:8px}
::-webkit-scrollbar-track{background:transparent}
::selection{background:#eaa24e;color:#1a1410}
input::placeholder{color:#6b6258}

.page{min-height:100vh;color:#f4efe7;font-family:'Space Grotesk',sans-serif;
  padding:0 24px 110px;
  background:radial-gradient(1100px 560px at 84% -10%,rgba(234,162,78,0.12),transparent 58%),radial-gradient(880px 520px at 6% 8%,rgba(139,108,217,0.10),transparent 56%),#0c0a09}
.wrap{max-width:1080px;margin:0 auto}
.loading{color:#9c9085;font-family:'IBM Plex Mono',monospace;font-size:13px;padding:80px 4px}
button{font-family:'Space Grotesk',sans-serif}
a{color:inherit}

/* ---------- HERO ---------- */
.hero{display:flex;flex-wrap:wrap;gap:48px;align-items:center;min-height:86vh;padding:48px 0 40px}
.hero-photo{flex:none;width:300px;height:400px;border-radius:18px;overflow:hidden;position:relative;
  box-shadow:0 40px 90px -40px rgba(0,0,0,.85);
  -webkit-user-select:none;user-select:none;-webkit-touch-callout:none;
  transition:transform .25s ease, box-shadow .25s ease}
.hero-photo.holding{transform:scale(.97);
  box-shadow:0 40px 90px -40px rgba(0,0,0,.85), 0 0 0 3px rgba(232,154,77,.55), 0 0 40px rgba(232,154,77,.25);
  transition:transform 2s ease, box-shadow .35s ease}
.hero-photo img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block;filter:grayscale(100%) contrast(1.04);
  -webkit-user-drag:none;pointer-events:none}
.hero-photo-face{position:absolute;top:4%;left:31%;width:38%;height:30%;z-index:3;
  -webkit-touch-callout:none;-webkit-user-select:none;user-select:none;cursor:default}
.hero-photo-fallback{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(circle at 50% 30%,#26221e,#0c0a09);font-size:150px;font-weight:700;color:#eaa24e}
.hero-text{flex:1;min-width:300px}
.hero-eyebrow{font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.34em;text-transform:uppercase;color:#eaa24e;margin-bottom:18px}
.hero-name{font-size:clamp(58px,9vw,112px);font-weight:700;letter-spacing:-.045em;line-height:.9;margin:0;
  background:linear-gradient(118deg,#fdf6ec 28%,#f2b568 62%,#e5705f 92%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.hero-tagline{margin-top:18px;font-size:18px;color:#cfc6bb}
.hero-bio{margin-top:22px;max-width:560px;font-size:15px;line-height:1.85;color:#9c9085}
.hero-roles{margin-top:18px;font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.05em;color:#7c7268}
.hero-cta{display:inline-block;margin-top:34px;background:linear-gradient(135deg,#f2b568,#e5705f);color:#1a1410;text-decoration:none;
  padding:14px 30px;border-radius:999px;font-weight:600;font-size:15px;box-shadow:0 14px 34px -12px rgba(229,112,95,.55);transition:transform .15s,filter .15s}
.hero-cta:hover{filter:brightness(1.07);transform:translateY(-2px)}

/* ---------- LIVE STRIP ---------- */
.live{position:relative;border-radius:18px;overflow:hidden;margin:0 0 72px;height:300px;background:#15110e}
.live img{width:100%;height:100%;object-fit:cover;display:block}
.live::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(12,10,9,.75),transparent 45%,rgba(12,10,9,.25))}
.live-cap{position:absolute;left:26px;bottom:22px;z-index:2}
.live-kicker{font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:#f2b568}
.live-title{margin-top:6px;font-size:18px;font-weight:600;color:#f4efe7}

#schedule{scroll-margin-top:16px}

/* ---------- MODE BAR → status pill ---------- */
.modebar{display:flex;flex-wrap:wrap;align-items:center;gap:13px;padding:12px 16px;border:1px solid;border-radius:15px;margin:0 0 30px}
.modebar.is-edit{background:linear-gradient(135deg,rgba(232,154,77,.13),rgba(229,112,95,.05));border-color:rgba(232,154,77,.28)}
.modebar.is-public{background:linear-gradient(135deg,rgba(95,184,122,.07),rgba(255,247,235,.02));border-color:rgba(255,240,220,.10)}
.dot{width:9px;height:9px;border-radius:50%;flex:none}
.modebar .dot{position:relative}
.modebar.is-edit .dot{animation:pulseDot 2.2s ease-out infinite}
@keyframes pulseDot{0%{box-shadow:0 0 0 0 rgba(232,154,77,.5)}70%{box-shadow:0 0 0 8px rgba(232,154,77,0)}100%{box-shadow:0 0 0 0 rgba(232,154,77,0)}}
.modebar .label{font-family:'IBM Plex Mono',monospace;font-size:11.5px;letter-spacing:.13em;text-transform:uppercase;color:#f4efe7;font-weight:500}
.modebar .hint{font-size:13px;color:#9c9085}
.modebar .right{margin-left:auto;display:flex;gap:10px;align-items:center}
.btn-ghost{background:rgba(0,0,0,.22);color:#cfc6bb;border:1px solid rgba(255,240,220,.14);cursor:pointer;font:600 12.5px 'Space Grotesk';padding:7px 15px;border-radius:999px;transition:all .15s}
.btn-ghost:hover{border-color:#e5705f;color:#e5705f;background:rgba(229,112,95,.08)}
.btn-signin{background:transparent;color:#eaa24e;border:none;cursor:pointer;font:600 13px 'Space Grotesk';padding:6px 4px}
.btn-signin:hover{color:#f2b568}

/* ---------- SIGN IN ---------- */
.signin{background:rgba(255,247,235,.03);border-radius:16px;padding:22px;margin-bottom:28px;max-width:460px}
.signin .title{font-size:16px;font-weight:600;margin-bottom:6px}
.signin .sub{font-size:13px;color:#9c9085;margin-bottom:16px}
.signin .fields{display:flex;flex-direction:column;gap:10px}
.signin .row{display:flex;gap:10px;flex-wrap:wrap}
.input{flex:1;min-width:200px;padding:12px 14px;background:rgba(0,0,0,.28);border:1px solid rgba(255,240,220,.1);
  border-radius:10px;color:#f4efe7;font:15px 'Space Grotesk';outline:none;color-scheme:dark}
.input:focus{border-color:#eaa24e}
.btn-amber{background:linear-gradient(135deg,#f2b568,#e5705f);color:#1a1410;border:none;border-radius:10px;padding:12px 22px;font:600 14px 'Space Grotesk';cursor:pointer}
.btn-amber:hover{filter:brightness(1.07)}
.error{color:#e5705f;font-size:13px}

/* ---------- SCHEDULE HEADER ---------- */
.header{display:flex;flex-wrap:wrap;gap:24px;justify-content:space-between;align-items:flex-end;margin-bottom:30px}
.eyebrow{font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:#eaa24e;margin-bottom:10px}
.h-title{font-size:40px;font-weight:700;letter-spacing:-.02em;line-height:1}
.h-sub{margin-top:8px;color:#9c9085;font-size:15px}
.stats{display:flex;gap:10px;flex-wrap:wrap}
.stat{background:rgba(255,247,235,.03);border:1px solid rgba(255,240,220,.08);border-radius:14px;padding:11px 18px;min-width:90px;transition:transform .15s ease,border-color .15s ease,background .15s ease}
.stat:hover{transform:translateY(-2px);border-color:rgba(232,154,77,.32);background:rgba(255,247,235,.05)}
.stat .k{font-family:'IBM Plex Mono',monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:#8a8179}
.stat .v{font-size:29px;font-weight:700;margin-top:7px;letter-spacing:-.02em;line-height:1}

/* ---------- TABS → segmented pill ---------- */
.toolbar{display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;align-items:center;margin-bottom:26px}
.tabs{display:inline-flex;gap:3px;background:rgba(255,247,235,.03);border:1px solid rgba(255,240,220,.08);border-radius:13px;padding:4px}
.tab{background:transparent;border:none;cursor:pointer;color:#9c9085;font:600 14px 'Space Grotesk';padding:8px 16px;border-radius:9px;transition:all .16s ease}
.tab:hover{color:#e7ddd0;background:rgba(255,247,235,.04)}
.tab.active{color:#f8efe2;background:linear-gradient(135deg,rgba(232,154,77,.24),rgba(229,112,95,.15));
  box-shadow:0 2px 10px -3px rgba(0,0,0,.45),inset 0 1px 0 rgba(255,255,255,.06)}
.btn-add{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,#f2b568,#e5705f);color:#1a1410;border:none;border-radius:999px;padding:11px 20px;font:600 14px 'Space Grotesk';cursor:pointer;box-shadow:0 12px 28px -12px rgba(229,112,95,.5)}
.btn-add:hover{filter:brightness(1.07)}
.btn-add .ico{font-size:18px;line-height:1}

/* ---------- ADD FORM ---------- */
.form{background:rgba(255,247,235,.03);border-radius:16px;padding:24px;margin-bottom:28px}
.form .title{font-size:16px;font-weight:600;margin-bottom:18px}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
.col-full{grid-column:1/-1}
.flabel{display:block;font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:#9c9085;margin-bottom:7px}
.field{width:100%;padding:12px 14px;background:rgba(0,0,0,.28);border:1px solid rgba(255,240,220,.1);border-radius:10px;color:#f4efe7;font:15px 'Space Grotesk';outline:none;color-scheme:dark}
.field:focus{border-color:#eaa24e;box-shadow:0 0 0 3px rgba(232,154,77,.12)}
/* Custom dark select — modern amber chevron, scoped to <select> so date inputs keep their picker */
select.field{appearance:none;-webkit-appearance:none;-moz-appearance:none;cursor:pointer;padding-right:42px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23eaa24e' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;background-size:13px}
select.field::-ms-expand{display:none}
.field option, select option{background-color:#16120e;color:#f4efe7;padding:10px}
.field option:checked, select option:checked{background-color:#2a1f14;color:#eaa24e}
.form-actions{display:flex;gap:12px;margin-top:20px}
.btn-amber-lg{background:linear-gradient(135deg,#f2b568,#e5705f);color:#1a1410;border:none;border-radius:10px;padding:12px 24px;font:600 14px 'Space Grotesk';cursor:pointer}
.btn-amber-lg:hover{filter:brightness(1.07)}
.btn-ghost-lg{background:transparent;color:#9c9085;border:none;border-radius:10px;padding:12px 8px;font:500 14px 'Space Grotesk';cursor:pointer}
.btn-ghost-lg:hover{color:#f4efe7}

/* ---------- CONFLICT BANNER ---------- */
.banner{display:flex;align-items:center;gap:12px;background:rgba(229,112,95,.09);border-left:2px solid #e5705f;border-radius:0 10px 10px 0;padding:14px 18px;margin-bottom:26px}
.banner .msg{font-size:14px;color:#f0c4bc}

/* ---------- EMPTY ---------- */
.empty{text-align:center;padding:90px 20px;color:#6b6258}
.empty .big{font-size:18px;color:#9c9085}
.empty .small{margin-top:8px;font-size:14px}

/* ---------- LIST (frameless rows) ---------- */
.list{display:flex;flex-direction:column}
.row{display:flex;flex-wrap:wrap;align-items:center;gap:16px;padding:18px 12px;border-bottom:1px solid rgba(255,240,220,.06);border-radius:8px;transition:background .15s}
.row:hover{background:rgba(255,247,235,.025)}
.row.conflict{box-shadow:inset 2px 0 0 #e5705f}
.statuspill{display:inline-flex;align-items:center;gap:8px;flex:none;width:130px;border:none;border-radius:999px;padding:6px 12px;font:600 13px 'Space Grotesk'}
button.statuspill{cursor:pointer}
.statuspill .sdot{width:8px;height:8px;border-radius:50%;flex:none}
.row .main{flex:1;min-width:200px}
.row .act{font-size:16px;font-weight:600}
.row .meta{margin-top:4px;font-size:13px;color:#9c9085}
.row .date{flex:none;font-family:'IBM Plex Mono',monospace;font-size:13px;color:#b8a89a;min-width:140px}
.badge-conflict{flex:none;font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:#e5705f}
.btn-x{flex:none;background:transparent;border:none;color:#6b6258;font-size:20px;cursor:pointer;padding:4px 8px;line-height:1;transition:color .15s}
.btn-x:hover{color:#e5705f}
.btn-edit{flex:none;background:transparent;border:none;color:#6b6258;font-size:15px;cursor:pointer;padding:4px 8px;line-height:1;transition:color .15s}
.btn-edit:hover{color:#eaa24e}
.card-actions{display:flex;align-items:center;gap:2px;flex:none}
.row.editing, .card.editing{outline:2px solid rgba(232,154,77,.55);outline-offset:-1px;background:rgba(232,154,77,.05)}

/* Quick template chips (form) */
.qt-hint{font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:#888891;margin:16px 0 8px}
.qt-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.qt-chip{display:inline-flex;align-items:center;gap:6px;background:rgba(255,247,235,.04);border:1px solid #2a2a31;border-radius:999px;padding:7px 13px;color:#cfc6bb;font:500 13px 'Space Grotesk',sans-serif;cursor:pointer;transition:all .15s}
.qt-chip:hover{background:rgba(232,154,77,.10);border-color:#e89a4d;color:#f4efe7}
.qt-chip.active{background:rgba(232,154,77,.18);border-color:#e89a4d;color:#f4efe7;box-shadow:0 0 0 1px rgba(232,154,77,.25)}
.qt-emoji{font-size:15px;line-height:1}
.qt-ico{display:inline-flex;align-items:center;justify-content:center;opacity:.9}
.qt-ico svg{display:block;width:16px;height:16px}
.qt-chip.active .qt-ico{opacity:1}
.qt-label{font-size:13px;font-weight:500}
.req-star{color:#e5705f;font-weight:700}
.booking-legend{font-size:11.5px;color:#8a8179;margin-top:10px;font-family:'IBM Plex Mono',monospace;letter-spacing:.02em}

/* Custom dark location picker (province → city/regency) */
.loc-picker{position:relative;width:100%}
.loc-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px;background:rgba(0,0,0,.28);border:1px solid rgba(255,240,220,.1);border-radius:10px;color:#f4efe7;font:16px 'Space Grotesk',sans-serif;cursor:pointer;text-align:left;transition:border-color .15s,box-shadow .15s}
.loc-trigger:hover{border-color:rgba(232,154,77,.5)}
.loc-trigger.open{border-color:#eaa24e;box-shadow:0 0 0 3px rgba(232,154,77,.12)}
.loc-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.loc-label.loc-ph{color:#6b6258}
.loc-caret{flex:none;color:#eaa24e;font-size:12px;transition:transform .18s}
.loc-trigger.open .loc-caret{transform:rotate(180deg)}
.loc-panel{margin-top:8px;max-height:288px;overflow-y:auto;background:#16120e;border:1px solid #2a2a31;border-radius:12px;padding:6px;box-shadow:0 24px 50px -20px rgba(0,0,0,.7)}
.loc-head{font-family:'IBM Plex Mono',monospace;font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:#7c7268;padding:8px 10px 6px}
.loc-row{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;background:transparent;border:none;border-radius:8px;padding:11px 12px;color:#e7ddd0;font:500 14px 'Space Grotesk',sans-serif;cursor:pointer;text-align:left;transition:background .12s,color .12s}
.loc-row:hover{background:rgba(232,154,77,.12);color:#f4efe7}
.loc-row-caret{flex:none;color:#7c7268;font-size:16px}
.loc-row:hover .loc-row-caret{color:#eaa24e}
.loc-row-city{padding-left:16px}
.loc-row.sel{color:#eaa24e;background:rgba(232,154,77,.08)}
.loc-check{flex:none;color:#eaa24e;font-size:13px}
.loc-back{width:100%;display:flex;align-items:center;gap:9px;background:#1b1510;border:none;border-radius:8px;padding:11px 12px;margin-bottom:6px;color:#cfc6bb;font:600 13.5px 'Space Grotesk',sans-serif;cursor:pointer;position:sticky;top:0;z-index:2}
.loc-back:hover{color:#eaa24e}
.loc-back-caret{font-size:18px;line-height:1;color:#eaa24e}
.loc-back-hint{margin-left:auto;font-family:'IBM Plex Mono',monospace;font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:#7c7268}

/* Date field with quick chips */
.datefield{display:flex;flex-direction:column;gap:7px}
.datechips{display:flex;flex-wrap:wrap;gap:4px}
.datechip{background:transparent;border:1px solid #2a2a31;border-radius:6px;padding:4px 9px;color:#9c9085;font:500 11px 'IBM Plex Mono',monospace;cursor:pointer;transition:all .15s}
.datechip:hover{border-color:#e89a4d;color:#eaa24e;background:rgba(232,154,77,.05)}

/* Input + helper-hint wrapper */
.inputwrap{display:flex;flex-direction:column;gap:6px}
.field-hint{font-size:11.5px;color:#7e776e;font-family:'Space Grotesk',sans-serif;line-height:1.4;padding-left:2px}

/* ---------- PHOTOS — inline badge on rows/cards ---------- */
.photo-badge{flex:none;display:inline-flex;align-items:center;gap:5px;background:rgba(232,154,77,.10);border:1px solid rgba(232,154,77,.35);border-radius:999px;padding:4px 10px;color:#eaa24e;font:600 12px 'Space Grotesk',sans-serif;cursor:pointer;transition:all .15s}
.photo-badge:hover{background:rgba(232,154,77,.20);border-color:#eaa24e}
.photo-badge-ico{font-size:13px;line-height:1}

/* ---------- PHOTO SECTION inside the form ---------- */
.photo-section{margin-top:28px;padding-top:22px;border-top:1px dashed rgba(255,240,220,.10)}
.photo-section-hint{padding:14px 16px;background:rgba(255,247,235,.025);border:1px dashed #2a2a31;border-radius:12px;margin-top:18px}
.photo-section-head{margin-bottom:14px}
.photo-section-title{font-size:14px;font-weight:600;color:#f4efe7;margin-bottom:4px}
.photo-section-sub{font-size:12.5px;color:#9c9085;line-height:1.5}
.photo-thumbs{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:14px}
.photo-thumb{position:relative;width:88px;height:88px;border-radius:10px;overflow:hidden;background:#15110e;border:1px solid #2a2a31}
.photo-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.photo-thumb-remove{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;background:rgba(0,0,0,.65);border:none;color:#f4efe7;font-size:16px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:background .15s}
.photo-thumb-remove:hover{background:rgba(229,112,95,.9)}
.photo-upload-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}

/* ---------- GALLERY ---------- */
.gallery{margin-top:80px;padding-top:50px;border-top:1px solid rgba(255,240,220,.06)}
.gallery-head{margin-bottom:24px}
.gallery-eyebrow{font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.32em;text-transform:uppercase;color:#eaa24e;margin-bottom:10px}
.gallery-title{font-size:38px;font-weight:700;letter-spacing:-.02em;margin:0 0 8px}
.gallery-sub{font-size:15px;color:#9c9085;margin:0;max-width:620px;line-height:1.6}
.gallery-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:26px}
.gallery-chip{display:inline-flex;align-items:center;gap:8px;background:rgba(255,247,235,.04);border:1px solid #2a2a31;border-radius:999px;padding:8px 14px;color:#cfc6bb;font:500 13px 'Space Grotesk',sans-serif;cursor:pointer;transition:all .15s}
.gallery-chip:hover{border-color:#e89a4d;color:#f4efe7}
.gallery-chip.active{background:rgba(232,154,77,.18);border-color:#e89a4d;color:#f4efe7}
.gallery-chip-count{font-family:'IBM Plex Mono',monospace;font-size:11px;color:#9c9085;background:rgba(0,0,0,.25);padding:2px 7px;border-radius:999px}
.gallery-chip.active .gallery-chip-count{color:#eaa24e}

/* Masonry-style grid via CSS columns — preserves aspect ratios elegantly */
.gallery-grid{columns:3 280px;column-gap:14px}
.gallery-tile{margin:0 0 14px;break-inside:avoid;border-radius:14px;overflow:hidden;background:#15110e;cursor:pointer;border:1px solid rgba(255,240,220,.06);transition:transform .25s ease, box-shadow .25s ease, border-color .15s}
.gallery-tile:hover{transform:translateY(-3px);box-shadow:0 24px 60px -20px rgba(0,0,0,.7);border-color:rgba(232,154,77,.5)}
.gallery-tile-imgwrap{position:relative;width:100%;background:#1a1410}
.gallery-tile-imgwrap img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}
.gallery-tile:hover .gallery-tile-imgwrap img{transform:scale(1.04)}
.gallery-tile-cap{padding:14px 16px 16px;background:linear-gradient(180deg,#15110e,#0f0c0a)}
.gallery-tile-title{font-size:14px;font-weight:600;color:#f4efe7;line-height:1.35;margin-bottom:5px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.gallery-tile-meta{font-family:'IBM Plex Mono',monospace;font-size:11px;color:#9c9085;letter-spacing:.02em;line-height:1.5;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.gallery-empty{padding:40px 20px;text-align:center;color:#7e776e;font:500 14px 'Space Grotesk',sans-serif;border:1px dashed #2a2a31;border-radius:14px}

/* ---------- LIGHTBOX ---------- */
.lightbox{position:fixed;inset:0;background:rgba(8,6,5,.94);z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px 110px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:lbFade .22s ease}
@keyframes lbFade{from{opacity:0}to{opacity:1}}
.lb-stage{flex:1;width:100%;max-width:1200px;display:flex;align-items:center;justify-content:center;min-height:0}
.lb-img{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px;box-shadow:0 40px 100px -30px rgba(0,0,0,.9);user-select:none;-webkit-user-drag:none}
.lb-cap{margin-top:18px;max-width:780px;text-align:center}
.lb-counter{font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#eaa24e;margin-bottom:8px}
.lb-cap-title{font-size:18px;font-weight:600;color:#f4efe7;line-height:1.35;margin-bottom:6px}
.lb-cap-meta{font-size:13px;color:#9c9085;line-height:1.55;font-family:'IBM Plex Mono',monospace}
.lb-remove{margin-top:12px;background:transparent;border:1px solid rgba(229,112,95,.5);color:#e5705f;border-radius:10px;padding:8px 18px;font:500 13px 'Space Grotesk',sans-serif;cursor:pointer;transition:all .15s}
.lb-remove:hover{background:rgba(229,112,95,.10);border-color:#e5705f}
.lb-close{position:absolute;top:16px;right:18px;background:rgba(0,0,0,.4);border:1px solid rgba(255,240,220,.15);width:42px;height:42px;border-radius:50%;color:#f4efe7;font-size:24px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:all .15s;z-index:2}
.lb-close:hover{background:rgba(229,112,95,.30);border-color:#e5705f}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.4);border:1px solid rgba(255,240,220,.15);width:48px;height:48px;border-radius:50%;color:#f4efe7;font-size:28px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:all .15s;z-index:2}
.lb-nav:hover{background:rgba(232,154,77,.30);border-color:#eaa24e;color:#eaa24e}
.lb-prev{left:18px}
.lb-next{right:18px}

@media (max-width:560px){
  .gallery{margin-top:60px;padding-top:36px}
  .gallery-title{font-size:28px}
  .gallery-sub{font-size:14px}
  .gallery-grid{columns:2 160px;column-gap:10px}
  .gallery-tile{margin-bottom:10px;border-radius:12px}
  .gallery-tile-cap{padding:10px 12px 12px}
  .gallery-tile-title{font-size:13px}
  .gallery-tile-meta{font-size:10px}
  .lightbox{padding:50px 12px 70px}
  .lb-nav{width:40px;height:40px;font-size:24px}
  .lb-prev{left:8px}
  .lb-next{right:8px}
  .lb-close{top:10px;right:10px}
  .lb-cap-title{font-size:15px}
  .lb-cap-meta{font-size:12px}
}
@media (max-width:400px){
  .gallery-grid{columns:1;column-gap:0}
}

/* Empty-state visuals — per-view */
.empty-cta{display:flex;justify-content:center;margin:28px 0 8px}
.list-empty{padding:0}
.empty-row{display:flex;align-items:center;gap:14px;padding:22px 20px;background:rgba(255,247,235,.02);border:1px dashed #2a2a31;border-radius:14px}
.empty-dot{width:8px;height:8px;border-radius:50%;background:#3a3a42;flex:none}
.empty-text{color:#7e776e;font:500 14px 'Space Grotesk',sans-serif}
.col-empty{padding:18px 14px;text-align:center;color:#5a5249;font:500 12px 'IBM Plex Mono',monospace;letter-spacing:.08em;text-transform:uppercase;border:1px dashed #25252b;border-radius:10px;background:rgba(255,247,235,.015);margin:0 4px}
.tl-label-empty{color:#5a5249;font-style:italic}
.tl-empty-hint{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);color:#7e776e;font:500 13px 'Space Grotesk',sans-serif;white-space:nowrap;padding:8px 14px;background:rgba(255,247,235,.03);border:1px dashed #2a2a31;border-radius:10px}

/* ---------- BOARD ---------- */
.board{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;align-items:start}
.column{background:rgba(255,247,235,.02);border-radius:16px;padding:16px}
.col-head{display:flex;align-items:center;gap:8px;margin-bottom:14px;padding:0 4px}
.col-head .ct{font-weight:600;font-size:14px}
.col-head .cc{margin-left:auto;font-family:'IBM Plex Mono',monospace;font-size:13px;color:#7c7268}
.col-cards{display:flex;flex-direction:column;gap:10px}
.card{background:rgba(255,247,235,.04);border-radius:12px;padding:15px}
.card.conflict{box-shadow:inset 2px 0 0 #e5705f}
.card .top{display:flex;justify-content:space-between;gap:8px}
.card .act{font-size:15px;font-weight:600;line-height:1.3}
.card .btn-x{font-size:18px;padding:0}
.card .meta{margin-top:7px;font-size:12px;color:#9c9085}
.card .daterow{margin-top:10px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.card .date{font-family:'IBM Plex Mono',monospace;font-size:12px;color:#b8a89a}
.card .badge-conflict{font-size:10px}
.btn-cycle{margin-top:12px;width:100%;background:transparent;border:1px dashed rgba(255,240,220,.14);border-radius:10px;padding:8px;color:#9c9085;font:600 12px 'Space Grotesk';cursor:pointer}
.btn-cycle:hover{border-color:#eaa24e;color:#eaa24e}

/* ---------- TIMELINE ---------- */
.timeline{background:rgba(255,247,235,.02);border-radius:18px;padding:22px;overflow:hidden}
.tl-monthsrow{display:flex;gap:16px}
.tl-spacer{flex:none;width:200px}
.tl-months{flex:1;position:relative;height:22px}
.tl-month{position:absolute;top:0;transform:translateX(-2px);font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:#7c7268}
.tl-rows{display:flex;flex-direction:column;gap:11px;margin-top:8px}
.tl-row{display:flex;gap:16px;align-items:center}
.tl-label{flex:none;width:200px;min-width:0;overflow:hidden}
.tl-actname{font-size:13.5px;font-weight:600;color:#f4efe7;white-space:nowrap;text-overflow:ellipsis;overflow:hidden;line-height:1.3}
.tl-actrole{display:flex;align-items:center;gap:6px;margin-top:4px;font-family:'IBM Plex Mono',monospace;font-size:10.5px;letter-spacing:.04em;color:#9c9085;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tl-actrole .tl-dot{width:6px;height:6px;border-radius:50%;flex:none}
.tl-track{flex:1;position:relative;height:40px;background:rgba(0,0,0,.28);border-radius:11px;overflow:visible}
.tl-bar{position:absolute;top:7px;bottom:7px;border-radius:8px;
  background:linear-gradient(180deg,var(--bbg),rgba(0,0,0,.18));border:1px solid var(--bc);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 3px 10px -5px rgba(0,0,0,.6);
  transition:filter .15s,transform .15s}
.tl-bar-point{border-radius:999px;min-width:14px}
.tl-bar-clickable{cursor:pointer}
.tl-bar-clickable:hover{filter:brightness(1.32) saturate(1.1);transform:translateY(-1px)}
.tl-barlabel{position:absolute;top:50%;transform:translateY(-50%);font-family:'IBM Plex Mono',monospace;font-size:11px;font-weight:500;white-space:nowrap;padding-left:9px;pointer-events:none;z-index:3}
.tl-barlabel-left{padding-left:0;padding-right:9px}
.tl-today{position:absolute;top:-6px;bottom:-6px;width:2px;background:linear-gradient(180deg,transparent,rgba(234,162,78,.9) 22%,rgba(234,162,78,.9) 78%,transparent);pointer-events:none;z-index:1}
.tl-today-tag{position:absolute;top:-20px;left:50%;transform:translateX(-50%);font-family:'IBM Plex Mono',monospace;font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:#eaa24e;background:rgba(234,162,78,.12);padding:2px 6px;border-radius:5px;white-space:nowrap}

/* ---------- CALENDAR ---------- */
.calendar{background:rgba(255,247,235,.02);border-radius:18px;padding:22px}
.cal-head{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.cal-month{font-size:20px;font-weight:600}
.cal-nav{margin-left:auto;display:flex;gap:8px}
.cal-nav button{background:transparent;border:1px solid rgba(255,240,220,.12);border-radius:10px;padding:8px 14px;color:#f4efe7;font-size:15px;cursor:pointer;transition:all .15s}
.cal-nav .today{color:#9c9085;font:600 13px 'Space Grotesk'}
.cal-nav button:hover{border-color:#eaa24e;color:#eaa24e;background:rgba(232,154,77,.06)}
.cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:6px}
.cal-weekdays div{text-align:left;font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:#7c7268;padding:4px 9px}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal-cell{min-height:96px;min-width:0;border:1px solid #222228;border-radius:10px;padding:8px;display:flex;flex-direction:column;gap:4px;background:rgba(255,247,235,.03);position:relative;transition:transform .14s ease,border-color .14s ease,box-shadow .14s ease,background .14s ease}
.cal-out{background:transparent;border-color:#1a1a1f}
.cal-out .cal-num{color:#4f4842}
.cal-past{background:rgba(255,247,235,.012)}
.cal-past .cal-num{opacity:.5}
.cal-past .cal-ev{opacity:.82}
.cal-today{border-color:#e89a4d;background:linear-gradient(160deg,rgba(234,162,78,.16),rgba(234,162,78,.04))}
.cal-today .cal-num{color:#eaa24e;font-weight:700}
.cal-cell-click{cursor:pointer}
.cal-cell-click:hover{transform:translateY(-2px);border-color:rgba(232,154,77,.55);box-shadow:0 14px 30px -16px rgba(232,154,77,.4);background:rgba(255,247,235,.055);z-index:1}
.cal-admin:hover::after{content:'+';position:absolute;bottom:6px;right:8px;font-size:15px;font-weight:700;color:rgba(232,154,77,.6);line-height:1}
.cal-admin.cal-has:hover::after{content:''}
.cal-num{font-family:'IBM Plex Mono',monospace;font-size:12px;align-self:flex-start;color:#cfc6bb}
.cal-ev{max-width:100%;min-width:0;border-radius:5px;padding:3px 7px;font-size:11px;line-height:1.3;color:#f4efe7;border-left:3px solid;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  word-break:break-word;hyphens:auto;pointer-events:none}
.cal-more{font-family:'IBM Plex Mono',monospace;font-size:11px;color:#9c9085;padding:1px 3px;align-self:flex-start;pointer-events:none}

/* ---------- DAY DETAIL MODAL ---------- */
.daydetail{position:fixed;inset:0;background:rgba(8,6,5,.78);z-index:9998;display:flex;align-items:flex-end;justify-content:center;padding:0;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);animation:ddFade .22s ease}
@keyframes ddFade{from{opacity:0}to{opacity:1}}
@media (min-width:640px){.daydetail{align-items:center;padding:24px}}
.dd-card-wrap{width:100%;max-width:560px;max-height:88vh;display:flex;flex-direction:column;
  background:linear-gradient(180deg,#1a1511,#120e0b);border:1px solid rgba(255,240,220,.10);
  border-radius:22px 22px 0 0;overflow:hidden;box-shadow:0 -20px 70px -20px rgba(0,0,0,.8);animation:ddSlide .28s cubic-bezier(.16,1,.3,1)}
@media (min-width:640px){.dd-card-wrap{border-radius:22px;box-shadow:0 40px 100px -30px rgba(0,0,0,.85)}}
@keyframes ddSlide{from{transform:translateY(40px);opacity:.4}to{transform:translateY(0);opacity:1}}
.dd-header{position:relative;padding:22px 24px 20px;
  background:linear-gradient(135deg,rgba(232,154,77,.16),rgba(229,112,95,.10) 60%,transparent);
  border-bottom:1px solid rgba(255,240,220,.08)}
.dd-today-badge{display:inline-block;font-family:'IBM Plex Mono',monospace;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:#1a1410;background:linear-gradient(135deg,#f2b568,#e5705f);padding:3px 9px;border-radius:999px;margin-bottom:9px;font-weight:600}
.dd-date{font-size:21px;font-weight:700;letter-spacing:-.01em;color:#f8f4ec;line-height:1.2}
.dd-count{margin-top:5px;font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.04em;color:#bda88f}
.dd-close{position:absolute;top:16px;right:16px;width:38px;height:38px;border-radius:50%;background:rgba(0,0,0,.3);border:1px solid rgba(255,240,220,.14);color:#f4efe7;font-size:22px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:all .15s}
.dd-close:hover{background:rgba(229,112,95,.30);border-color:#e5705f}
.dd-body{padding:18px 20px;overflow-y:auto;flex:1}
.dd-list{display:flex;flex-direction:column;gap:12px}
.dd-card{background:rgba(255,247,235,.035);border:1px solid rgba(255,240,220,.07);border-left:3px solid;border-radius:12px;padding:14px 16px}
.dd-card-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:9px}
.dd-pill{display:inline-flex;align-items:center;gap:7px;border-radius:999px;padding:4px 11px;font:600 12px 'Space Grotesk',sans-serif}
.dd-pill .sdot{width:7px;height:7px;border-radius:50%}
.dd-range{margin-left:auto;font-family:'IBM Plex Mono',monospace;font-size:12px;color:#b8a89a}
.dd-act{font-size:16px;font-weight:600;color:#f4efe7;line-height:1.35}
.dd-meta{margin-top:5px;font-size:13px;color:#9c9085}
.dd-thumbs{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.dd-thumb{width:70px;height:70px;border-radius:9px;overflow:hidden;cursor:pointer;border:1px solid #2a2a31;transition:transform .15s,border-color .15s}
.dd-thumb:hover{transform:scale(1.05);border-color:#eaa24e}
.dd-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.dd-actions{display:flex;gap:8px;margin-top:13px}
.dd-btn{flex:1;border:1px solid rgba(255,240,220,.12);background:transparent;border-radius:9px;padding:9px;font:600 13px 'Space Grotesk',sans-serif;cursor:pointer;transition:all .15s}
.dd-btn-edit{color:#eaa24e}
.dd-btn-edit:hover{background:rgba(232,154,77,.10);border-color:#eaa24e}
.dd-btn-del{color:#e5705f}
.dd-btn-del:hover{background:rgba(229,112,95,.10);border-color:#e5705f}
.dd-empty{text-align:center;padding:34px 20px}
.dd-empty-ico{font-size:38px;margin-bottom:12px;opacity:.7}
.dd-empty-title{font-size:17px;font-weight:600;color:#cfc6bb;margin-bottom:6px}
.dd-empty-sub{font-size:13.5px;color:#8a8179;line-height:1.55;max-width:340px;margin:0 auto}
.dd-foot{padding:16px 20px 20px;border-top:1px solid rgba(255,240,220,.07)}
.dd-add{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:8px;background:linear-gradient(135deg,#f2b568,#e5705f);color:#1a1410;border:none;border-radius:12px;padding:13px;font:600 14.5px 'Space Grotesk',sans-serif;cursor:pointer;box-shadow:0 14px 30px -14px rgba(229,112,95,.6);transition:filter .15s,transform .15s}
.dd-add:hover{filter:brightness(1.07);transform:translateY(-1px)}
.dd-add .ico{font-size:18px;line-height:1}
.dd-invite{font-size:13.5px;color:#cfc6bb;margin-bottom:12px;text-align:center;line-height:1.5}
.dd-invite-muted{color:#8a8179}
.dd-ghost-btn{width:100%;background:transparent;border:1px solid rgba(255,240,220,.14);color:#cfc6bb;border-radius:12px;padding:12px;font:600 14px 'Space Grotesk',sans-serif;cursor:pointer;transition:all .15s}
.dd-ghost-btn:hover{border-color:#eaa24e;color:#eaa24e}
.dd-wa{background:linear-gradient(135deg,#25d366,#128c7e);color:#fff}
.dd-wa:hover{filter:brightness(1.06)}
.dd-wa-ico{display:inline-flex;align-items:center;color:#fff}

/* booking request form */
.dd-header-req{display:flex;align-items:center;gap:12px}
.dd-back{flex:none;width:36px;height:36px;border-radius:50%;background:rgba(0,0,0,.3);border:1px solid rgba(255,240,220,.14);color:#f4efe7;font-size:22px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:all .15s;position:static}
.dd-back:hover{background:rgba(232,154,77,.22);border-color:#eaa24e;color:#eaa24e}
.dd-header-req .dd-header-main{flex:1}
.dd-header-req .dd-close{position:static}
.booking{padding-bottom:4px}
.booking-intro{font-size:13px;color:#9c9085;line-height:1.6;margin-bottom:18px;padding:12px 14px;background:rgba(37,211,102,.06);border:1px solid rgba(37,211,102,.20);border-radius:12px}
.dd-textarea{resize:vertical;min-height:64px;font:15px 'Space Grotesk',sans-serif;line-height:1.5}
.booking-foot{margin-top:12px;text-align:center;font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.04em;color:#7c7268}

/* ---------- EXIT EDIT MODE (bottom) ---------- */
.exitbar{margin-top:64px;padding-top:32px;border-top:1px solid rgba(255,240,220,.06);display:flex;justify-content:center}
.exitbar-inner{display:flex;align-items:center;gap:20px;flex-wrap:wrap;justify-content:space-between;
  background:linear-gradient(160deg,rgba(232,154,77,.07),rgba(255,247,235,.02));
  border:1px solid rgba(255,240,220,.09);border-radius:18px;padding:22px 24px;max-width:620px;width:100%}
.exitbar-text{flex:1;min-width:220px}
.exitbar-title{font-size:15px;font-weight:600;color:#f4efe7}
.exitbar-sub{margin-top:4px;font-size:13px;color:#9c9085;line-height:1.55}
.btn-exit{flex:none;display:inline-flex;align-items:center;gap:9px;background:linear-gradient(135deg,#f2b568,#e5705f);color:#1a1410;border:none;border-radius:999px;padding:13px 26px;font:600 14.5px 'Space Grotesk',sans-serif;cursor:pointer;box-shadow:0 14px 32px -12px rgba(229,112,95,.55);transition:filter .15s,transform .15s}
.btn-exit:hover{filter:brightness(1.07);transform:translateY(-1px)}
.btn-exit-ico{font-size:16px;line-height:1}

/* ---------- FOOTER ---------- */
.footer{margin-top:36px;text-align:center;font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.06em;color:#4f4842}

@media (max-width:820px){
  .hero{flex-direction:column;align-items:flex-start;min-height:auto;gap:30px;padding-top:36px}
  .hero-photo{width:100%;height:400px}
  .live{height:220px}
}
@media (max-width:560px){
  .page{padding:0 14px 70px}
  .stats{gap:9px}
  .row .date{min-width:0}
}

/* ============================================================
   DEVICE COMPATIBILITY — touch, notches, rotation, small screens
   ============================================================ */

/* Prevent iOS double-tap-zoom delay on tappable elements */
button, .tab, .qt-chip, .datechip, .btn-edit, .btn-x, .hero-cta { touch-action: manipulation; }

/* Long-press hot zone: block ALL native gestures (zoom, scroll, callout) */
.hero-photo-face { touch-action: none; -webkit-tap-highlight-color: transparent; }
.hero-photo { -webkit-tap-highlight-color: transparent; }

/* iOS auto-zooms on inputs with font-size < 16px — bump to 16px */
.input, .field { font-size: 16px; }

/* Safe-area insets for notched/cutout devices (iPhone X+, Android with cutouts) */
@supports (padding: max(0px)) {
  .page {
    padding-left: max(24px, env(safe-area-inset-left));
    padding-right: max(24px, env(safe-area-inset-right));
    padding-bottom: max(110px, calc(70px + env(safe-area-inset-bottom)));
  }
}

/* Bigger tap targets on touch devices (Apple HIG: ≥44px, Android: ≥48dp) */
@media (pointer: coarse) {
  .btn-edit, .btn-x { min-width: 40px; min-height: 40px; padding: 8px 10px; display:inline-flex; align-items:center; justify-content:center; }
  .tab { padding: 10px 0; }
  .qt-chip { padding: 10px 14px; }
  .datechip { padding: 8px 12px; font-size: 12px; }
  .cal-nav button { padding: 10px 16px; }
  .btn-cycle { padding: 12px; }
}

/* Respect users who request reduced motion */
@media (prefers-reduced-motion: reduce) {
  .hero-photo, .hero-photo.holding { transition: box-shadow .2s ease; transform: none; }
  .hero-cta:hover { transform: none; }
  * { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; scroll-behavior: auto !important; }
  /* Logo is a colour-only shimmer (no element motion) — keep it flowing even under reduced-motion */
  .hero-logo-mask { animation-duration: 3.2s !important; animation-iteration-count: infinite !important; }
}

/* Landscape phones — hero/live shouldn't dominate the screen */
@media (orientation: landscape) and (max-height: 500px) {
  .hero { min-height: auto; padding-top: 22px; gap: 22px; flex-direction: row; }
  .hero-photo { width: 240px; height: 280px; max-width: 45vw; }
  .hero-text { min-width: 0; }
  .live { height: 180px; }
}

/* Very small phones (≤400px wide) — tighten everything */
@media (max-width:400px){
  .page{padding:0 12px 70px}
  .hero{gap:22px;padding-top:28px}
  .hero-photo{height:360px}
  .hero-name{font-size:clamp(44px,12vw,76px)}
  .hero-bio{font-size:14px;line-height:1.7;margin-top:18px}
  .hero-cta{padding:12px 24px;font-size:14px;margin-top:24px}
  .live{height:170px;margin-bottom:48px}
  .live-cap{left:18px;bottom:16px}
  .modebar{gap:9px;padding:11px 13px;margin-bottom:22px}
  .modebar .hint{display:none}
  .modebar .right{margin-left:auto}
  .header{margin-bottom:22px}
  .h-title{font-size:30px}
  .stat{padding:9px 13px;min-width:72px;border-radius:12px}
  .stat .v{font-size:23px;margin-top:5px}
  .stats{gap:8px}
  .toolbar{gap:10px;margin-bottom:20px}
  .tabs{gap:2px;padding:3px;width:100%;justify-content:space-between}
  .tab{font-size:13px;padding:8px 11px;flex:1;text-align:center}
  .btn-add{padding:9px 14px;font-size:13px}
  .form,.signin{padding:18px;border-radius:14px}
  .form-actions{flex-wrap:wrap}
  .form-actions .btn-amber-lg{flex:1;min-width:140px}
  .timeline{padding:14px}
  .tl-label, .tl-spacer{width:118px}
  .tl-actname{font-size:12.5px}
  .tl-actrole{font-size:10px}
  .tl-track{height:34px}
  .tl-barlabel{font-size:10px;padding-left:6px}
  .tl-barlabel-left{padding-right:6px}
  .tl-empty-hint{font-size:12px;padding:6px 10px;white-space:normal;text-align:center;max-width:90%}
  .calendar{padding:12px}
  .cal-head{gap:8px;margin-bottom:12px}
  .cal-month{font-size:17px}
  .cal-nav button{padding:6px 10px;font-size:14px}
  .cal-nav .today{font-size:12px}
  .cal-weekdays{gap:3px}
  .cal-weekdays div{padding:3px 4px;font-size:10px;letter-spacing:.04em}
  .cal-grid{gap:3px}
  .cal-cell{min-height:62px;padding:4px;gap:2px}
  .cal-num{font-size:11px}
  .cal-ev{font-size:9px;padding:1px 4px;border-left-width:2px;-webkit-line-clamp:1}
  .cal-more{font-size:9px}
  .dd-date{font-size:18px}
  .dd-body{padding:16px}
  .dd-thumb{width:60px;height:60px}
  .exitbar{margin-top:48px;padding-top:24px}
  .exitbar-inner{padding:18px;gap:14px}
  .btn-exit{width:100%;justify-content:center}
  .empty-row{padding:18px 16px}
  .empty-text{font-size:13px}
  .col-empty{padding:14px 10px;font-size:11px;letter-spacing:.04em}
  .row{padding:14px 8px;gap:12px}
  .statuspill{width:auto;min-width:110px;font-size:12px}
  .qt-row{gap:6px;margin-bottom:16px}
  .qt-chip{padding:8px 11px}
  .qt-label{font-size:12px}
  .banner{padding:12px 14px}
  .banner .msg{font-size:13px}
}

/* Touch-only devices: disable :hover state retention (avoids "stuck hover" on tap) */
@media (hover: none) {
  .row:hover { background: transparent; }
  .qt-chip:hover { background: rgba(255,247,235,.04); border-color: #2a2a31; color: #cfc6bb; }
  .datechip:hover { border-color: #2a2a31; color: #9c9085; background: transparent; }
}

/* ============================================================
   SYIFA — hero logo, music & social, services
   ============================================================ */
.hero-logo{margin:0 0 4px;line-height:1;background:none;-webkit-text-fill-color:initial}
/* Signature logo: shape stays static, a soft white→orange gradient flows back & forth inside it */
.hero-logo-mask{display:block;width:min(440px,82%);aspect-ratio:1500/542;
  -webkit-mask:url(assets/syifa-logo.png) center/contain no-repeat;
  mask:url(assets/syifa-logo.png) center/contain no-repeat;
  background:linear-gradient(105deg,
    #e6852c 0%, #ef9e42 22%, #ffcf94 41%, #fff6ea 50%, #ffcf94 59%, #ef9e42 78%, #e6852c 100%);
  background-size:220% 100%;
  animation:logoWave 3.2s ease-in-out infinite;
  filter:drop-shadow(0 0 16px rgba(232,140,60,.4))}
@keyframes logoWave{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
.hero-ctas{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px}
.hero-cta-ghost{background:transparent;color:#cfc6bb;border:1px solid rgba(255,240,220,.18);box-shadow:none}
.hero-cta-ghost:hover{border-color:#eaa24e;color:#eaa24e;filter:none;transform:translateY(-2px)}

/* shared section headers */
.music, .services{margin:0 0 76px}
.sec-head{margin-bottom:26px}
.sec-eyebrow{font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:#eaa24e;margin-bottom:10px}
.sec-title{font-size:34px;font-weight:700;letter-spacing:-.02em;margin:0 0 8px}
.sec-sub{font-size:15px;color:#9c9085;margin:0;max-width:640px;line-height:1.6}

/* music & social */
.music-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:18px;align-items:start}
.music-player{min-width:0}
.music-player iframe{display:block;width:100%;border:0}
.music-links{display:flex;flex-direction:column;gap:10px}
.plat{display:flex;align-items:center;gap:13px;padding:13px 16px;border-radius:14px;background:rgba(255,247,235,.03);border:1px solid rgba(255,240,220,.08);text-decoration:none;color:#f4efe7;transition:transform .15s,border-color .15s,background .15s}
.plat:hover{transform:translateY(-2px);border-color:rgba(232,154,77,.4);background:rgba(255,247,235,.055)}
.plat-ico{flex:none;width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.28)}
.plat-spotify .plat-ico{color:#1DB954}
.plat-youtube .plat-ico{color:#FF0000}
.plat-ig .plat-ico{color:#E1306C}
.plat-tiktok .plat-ico{color:#f4efe7}
.plat-txt{flex:1;display:flex;flex-direction:column;min-width:0}
.plat-txt b{font-size:15px;font-weight:600}
.plat-txt small{font-size:12px;color:#9c9085;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.plat-go{flex:none;color:#7c7268;font-size:15px}
.plat:hover .plat-go{color:#eaa24e}

/* services */
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;align-items:start}
.svc-card{background:rgba(255,247,235,.03);border:1px solid rgba(255,240,220,.08);border-radius:16px;padding:20px}
.svc-cat{font-size:15px;font-weight:700;color:#f4efe7}
.svc-cat-mt{margin-top:18px}
.svc-note{font-family:'IBM Plex Mono',monospace;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:#7c7268;margin-top:3px;margin-bottom:12px}
.svc-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.svc-list li{display:grid;grid-template-columns:1fr auto;gap:2px 12px;padding-bottom:10px;border-bottom:1px solid rgba(255,240,220,.06)}
.svc-list li:last-child{border-bottom:none;padding-bottom:0}
.svc-name{font-size:14px;font-weight:600;color:#f4efe7}
.svc-price{font-family:'IBM Plex Mono',monospace;font-size:13px;color:#eaa24e;text-align:right;white-space:nowrap;align-self:start}
.svc-desc{grid-column:1/2;font-size:12.5px;color:#9c9085;line-height:1.45}
.svc-cta{margin-top:16px;width:100%;display:inline-flex;align-items:center;justify-content:center;gap:6px;background:rgba(232,154,77,.12);border:1px solid rgba(232,154,77,.42);color:#eaa24e;border-radius:11px;padding:11px;font:600 13.5px 'Space Grotesk',sans-serif;cursor:pointer;transition:all .15s}
.svc-cta:hover{background:rgba(232,154,77,.2);border-color:#eaa24e;transform:translateY(-1px)}
.svc-cta-row{display:flex;gap:8px;margin-top:16px}
.svc-cta-row .svc-cta{margin-top:0;flex:1}
.svc-cta-ghost{background:transparent;color:#cfc6bb;border-color:rgba(255,240,220,.16)}
.svc-cta-ghost:hover{background:rgba(255,247,235,.05);border-color:#eaa24e;color:#eaa24e}
.svc-fine{margin-top:12px;font-size:12px;color:#7e776e;line-height:1.5;text-align:center}
.svc-mainbook{margin-top:18px;display:flex;flex-wrap:wrap;gap:18px;align-items:center;justify-content:space-between;
  background:linear-gradient(135deg,rgba(232,154,77,.14),rgba(229,112,95,.06));border:1px solid rgba(232,154,77,.28);border-radius:18px;padding:22px 24px}
.svc-mainbook-txt{flex:1;min-width:240px}
.svc-mainbook-title{font-size:17px;font-weight:700;color:#f4efe7}
.svc-mainbook-sub{margin-top:5px;font-size:13.5px;color:#cfc6bb;line-height:1.55;max-width:560px}
.svc-mainbook-btn{flex:none;background:linear-gradient(135deg,#f2b568,#e5705f);color:#1a1410;border:none;border-radius:999px;padding:13px 26px;font:600 14.5px 'Space Grotesk',sans-serif;cursor:pointer;box-shadow:0 14px 32px -12px rgba(229,112,95,.55);transition:filter .15s,transform .15s}
.svc-mainbook-btn:hover{filter:brightness(1.07);transform:translateY(-1px)}
@media (max-width:520px){
  .svc-cta-row{flex-direction:column}
  .svc-mainbook-btn{width:100%}
}

@media (max-width:760px){
  .music-grid{grid-template-columns:1fr}
  .sec-title{font-size:27px}
  .music, .services{margin-bottom:56px}
}
@media (max-width:400px){
  .hero-logo-mask{width:88%}
  .sec-title{font-size:24px}
  .svc-card{padding:16px}
}
