/* ============================ Rayor Agenda ============================ */
:root{
  --bg:#0b1020; --panel:#111831; --panel-2:#0e1429; --card:#161f3a;
  --ink:#eaf0ff; --mut:#8a97b8; --mut-2:#5e6c92;
  --line:#222d4d; --line-2:#2b385e;
  --ac:#3b6dff; --ac-2:#07297e; --ac-ink:#fff;
  --grad:linear-gradient(135deg,#3b6dff,#7b3bff);
  --ok:#2dd4a7; --warn:#ffb020; --danger:#ff5d6c;
  --shadow:0 18px 50px -20px rgba(0,0,0,.7);
  --radius:14px; --side-w:262px; --hour-h:48px;
  color-scheme:dark;
}
html[data-theme="light"]{
  --bg:#f3f5fb; --panel:#ffffff; --panel-2:#f7f9fe; --card:#ffffff;
  --ink:#10182e; --mut:#5b678a; --mut-2:#93a0c0;
  --line:#e6eaf5; --line-2:#dde3f2;
  --ac:#2f63ff; --ac-2:#07297e; --ac-ink:#fff;
  --shadow:0 16px 44px -22px rgba(20,40,90,.35);
  color-scheme:light;
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;background:var(--bg);color:var(--ink);
  font-family:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  -webkit-font-smoothing:antialiased;font-size:14px;overflow:hidden}
button{font-family:inherit;cursor:pointer}
input,select,textarea{font-family:inherit;font-size:14px}
::selection{background:color-mix(in srgb,var(--ac) 35%,transparent)}

/* ----------------------------- LANDING ----------------------------- */
body.landing{overflow:auto}
.hero{min-height:100vh;display:flex;flex-direction:column;
  background:
   radial-gradient(900px 500px at 80% -10%, rgba(123,59,255,.20), transparent 60%),
   radial-gradient(800px 500px at 0% 110%, rgba(59,109,255,.20), transparent 55%),
   var(--bg)}
.hero-nav{display:flex;justify-content:space-between;align-items:center;padding:20px 26px}
.logo{display:flex;align-items:center;gap:9px;color:var(--ink);text-decoration:none;font-size:18px;font-weight:600}
.logo b{font-weight:800}
.logo-mark{font-size:20px}
.ghost{color:var(--mut);text-decoration:none;font-size:14px;border:1px solid var(--line);padding:8px 14px;border-radius:10px}
.ghost:hover{color:var(--ink);border-color:var(--line-2)}
.hero-in{flex:1;display:flex;flex-direction:column;justify-content:center;max-width:760px;margin:0 auto;padding:30px 26px;text-align:center}
.eyebrow{align-self:center;font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ac);
  background:color-mix(in srgb,var(--ac) 14%,transparent);padding:6px 12px;border-radius:99px}
.hero h1{font-size:clamp(38px,7vw,68px);line-height:1.02;margin:22px 0 14px;font-weight:800;letter-spacing:-.02em}
.grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.lead{font-size:clamp(15px,2.2vw,19px);color:var(--mut);max-width:620px;margin:0 auto 30px;line-height:1.6}
.cta{display:inline-block;background:var(--grad);color:#fff;text-decoration:none;font-weight:700;
  padding:15px 30px;border-radius:14px;font-size:16px;box-shadow:0 14px 34px -12px rgba(59,109,255,.7);transition:transform .15s}
.cta:hover{transform:translateY(-2px)}
.hero-feats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;max-width:640px;margin:42px auto 0}
.hero-feats div{background:color-mix(in srgb,var(--panel) 70%,transparent);border:1px solid var(--line);
  border-radius:12px;padding:14px 12px;font-size:13px;color:var(--ink);display:flex;flex-direction:column;gap:7px;align-items:center}
.hero-feats span{font-size:22px}
.hero-foot{text-align:center;padding:26px;color:var(--mut);font-size:13px}
.hero-foot a{color:var(--mut);text-decoration:none}.hero-foot a:hover{color:var(--ink)}
@media(max-width:560px){.hero-feats{grid-template-columns:repeat(2,1fr)}}

/* ----------------------------- APP SHELL ----------------------------- */
#app{display:grid;grid-template-columns:var(--side-w) 1fr;height:100vh;height:100dvh}
.side{background:var(--panel-2);border-right:1px solid var(--line);display:flex;flex-direction:column;min-height:0}
.side-top{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 4px}
.side-close{display:none}
.new-btn{margin:14px 16px 6px;background:var(--grad);color:#fff;border:none;border-radius:12px;padding:12px;font-weight:700;
  font-size:14px;display:flex;align-items:center;justify-content:center;gap:7px;box-shadow:0 10px 24px -12px rgba(59,109,255,.8)}
.new-btn span{font-size:18px;line-height:1}
.new-btn:hover{filter:brightness(1.06)}
.mini{padding:8px 12px 6px}
.mini-head{display:flex;align-items:center;justify-content:space-between;padding:2px 6px 8px}
.mini-head b{font-size:13px;font-weight:700}
.mini-head button{background:none;border:none;color:var(--mut);font-size:16px;padding:2px 7px;border-radius:7px}
.mini-head button:hover{background:var(--card);color:var(--ink)}
.mini-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px}
.mini-grid span{font-size:10px;color:var(--mut-2);text-align:center;padding:3px 0}
.mini-grid button{aspect-ratio:1;border:none;background:none;color:var(--ink);font-size:11px;border-radius:50%;padding:0}
.mini-grid button.out{color:var(--mut-2)}
.mini-grid button.today{background:var(--ac);color:#fff;font-weight:700}
.mini-grid button.sel{box-shadow:inset 0 0 0 1.5px var(--ac)}
.mini-grid button.has::after{content:"";display:block;width:4px;height:4px;border-radius:50%;background:var(--ac);margin:1px auto 0}
.mini-grid button:hover{background:var(--card)}
.cal-list-h{display:flex;align-items:center;justify-content:space-between;padding:14px 18px 6px;font-size:12px;
  font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--mut)}
.cal-list{list-style:none;margin:0;padding:0 8px;overflow:auto;flex:1;min-height:40px}
.cal-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:10px;cursor:pointer}
.cal-item:hover{background:var(--card)}
.cal-item:hover .cal-edit{opacity:1}
.cb{width:17px;height:17px;border-radius:5px;border:2px solid var(--c);flex:none;display:grid;place-items:center}
.cal-item.on .cb{background:var(--c)}
.cb svg{width:11px;height:11px;opacity:0}.cal-item.on .cb svg{opacity:1}
.cal-name{flex:1;font-size:13.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cal-item.off .cal-name{color:var(--mut)}
.cal-edit{opacity:0;background:none;border:none;color:var(--mut);font-size:13px;padding:2px 5px;border-radius:6px;transition:opacity .15s}
.cal-edit:hover{background:var(--panel);color:var(--ink)}
.side-foot{padding:12px 16px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:4px}
.link-btn{background:none;border:none;color:var(--mut);text-align:left;text-decoration:none;font-size:13.5px;padding:7px 8px;border-radius:8px;display:block}
.link-btn:hover{background:var(--card);color:var(--ink)}

/* topbar */
.main{display:flex;flex-direction:column;min-width:0;min-height:0}
.topbar{display:flex;align-items:center;gap:10px;padding:12px 18px;border-bottom:1px solid var(--line);background:var(--panel-2);flex-wrap:nowrap}
.icon-btn{background:none;border:1px solid transparent;color:var(--ink);font-size:17px;width:36px;height:36px;border-radius:10px;display:grid;place-items:center;flex:none}
.icon-btn:hover{background:var(--card)}
.today-btn{border:1px solid var(--line-2);background:var(--panel);color:var(--ink);border-radius:10px;padding:8px 14px;font-weight:600;font-size:13.5px}
.today-btn:hover{border-color:var(--ac)}
.nav-arrows{display:flex;gap:2px}
.nav-arrows .icon-btn{font-size:22px;width:32px;height:32px}
.period{font-size:18px;font-weight:700;margin:0 0 0 4px;text-transform:capitalize;white-space:nowrap}
.spacer{flex:1}
.search-box input{background:var(--panel);border:1px solid var(--line-2);color:var(--ink);border-radius:10px;padding:8px 12px;width:170px;outline:none}
.search-box input:focus{border-color:var(--ac)}
.views{display:flex;background:var(--panel);border:1px solid var(--line-2);border-radius:10px;padding:2px}
.views button{background:none;border:none;color:var(--mut);padding:7px 12px;border-radius:8px;font-size:13px;font-weight:600}
.views button.on{background:var(--ac);color:#fff}
.bell{position:relative}
.bell .badge{position:absolute;top:3px;right:3px;min-width:15px;height:15px;background:var(--danger);color:#fff;border-radius:99px;font-size:9px;font-weight:700;display:grid;place-items:center;padding:0 3px}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--grad);display:grid;place-items:center;color:#fff;font-weight:700;font-size:14px;flex:none;background-size:cover;background-position:center;cursor:pointer}
.only-mobile{display:none}

.view-host{flex:1;overflow:auto;min-height:0;position:relative}

/* ----------------------------- MONTH ----------------------------- */
.month{display:flex;flex-direction:column;height:100%}
.dow{display:grid;grid-template-columns:repeat(7,1fr);border-bottom:1px solid var(--line)}
.dow span{padding:8px 10px;font-size:12px;font-weight:600;color:var(--mut);text-transform:uppercase;letter-spacing:.03em}
.mgrid{display:grid;grid-template-columns:repeat(7,1fr);grid-auto-rows:1fr;flex:1;min-height:560px}
.mcell{border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:5px 5px 2px;min-height:96px;display:flex;flex-direction:column;gap:2px;overflow:hidden;cursor:pointer}
.mcell:nth-child(7n){border-right:none}
.mcell.out{background:color-mix(in srgb,var(--panel-2) 55%,var(--bg))}
.mcell .dn{align-self:flex-end;font-size:12.5px;color:var(--ink);width:24px;height:24px;display:grid;place-items:center;border-radius:50%;font-weight:600}
.mcell.out .dn{color:var(--mut-2)}
.mcell.today .dn{background:var(--ac);color:#fff}
.mev{font-size:11.5px;padding:2px 6px;border-radius:6px;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.45;display:flex;gap:5px;align-items:center}
.mev .t{opacity:.85;font-variant-numeric:tabular-nums}
.mev.dot{background:transparent!important;color:var(--ink);padding-left:2px}
.mev.dot::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--c);flex:none}
.mmore{font-size:11px;color:var(--mut);padding:1px 6px;font-weight:600}

/* ----------------------------- TIME GRID (week/day) ----------------------------- */
.tg{display:grid;grid-template-columns:54px 1fr;min-height:100%}
.tg-allday{grid-column:1/3;display:grid;grid-template-columns:54px 1fr;border-bottom:2px solid var(--line);background:var(--panel-2);position:sticky;top:0;z-index:5}
.tg-allday .lbl{font-size:10px;color:var(--mut);padding:6px 4px;text-align:right}
.ad-cols{display:grid}
.ad-col{border-left:1px solid var(--line);padding:3px;min-height:26px;display:flex;flex-direction:column;gap:2px}
.tg-head{grid-column:1/3;display:grid;grid-template-columns:54px 1fr;position:sticky;top:0;z-index:6;background:var(--panel-2);border-bottom:1px solid var(--line)}
.tg-head .corner{}
.dh-cols{display:grid}
.dh{padding:7px 4px;text-align:center;border-left:1px solid var(--line)}
.dh .wd{font-size:11px;color:var(--mut);text-transform:uppercase}
.dh .nd{font-size:20px;font-weight:700;margin-top:2px;width:36px;height:36px;line-height:36px;border-radius:50%;display:inline-block}
.dh.today .nd{background:var(--ac);color:#fff}
.tg-body{grid-column:1/3;display:grid;grid-template-columns:54px 1fr;position:relative}
.hours{display:flex;flex-direction:column}
.hours .h{height:var(--hour-h);font-size:11px;color:var(--mut);text-align:right;padding-right:6px;transform:translateY(-7px)}
.grid-cols{position:relative;display:grid}
.gcol{border-left:1px solid var(--line);position:relative}
.gcol .hl{height:var(--hour-h);border-bottom:1px solid var(--line)}
.gcol .hl.half{border-bottom:1px dashed color-mix(in srgb,var(--line) 60%,transparent)}
.tev{position:absolute;left:3px;right:3px;border-radius:8px;padding:3px 7px;color:#fff;font-size:12px;overflow:hidden;
  box-shadow:0 2px 8px -2px rgba(0,0,0,.5);cursor:pointer;border-left:3px solid rgba(255,255,255,.55)}
.tev .tt{font-weight:600;line-height:1.25}
.tev .tm{opacity:.9;font-size:10.5px}
.nowline{position:absolute;left:0;right:0;height:2px;background:var(--danger);z-index:4;pointer-events:none}
.nowline::before{content:"";position:absolute;left:-4px;top:-3px;width:8px;height:8px;border-radius:50%;background:var(--danger)}

/* ----------------------------- AGENDA ----------------------------- */
.agenda{max-width:760px;margin:0 auto;padding:18px}
.ag-day{display:flex;gap:16px;padding:14px 6px;border-bottom:1px solid var(--line)}
.ag-date{flex:none;width:64px;text-align:center}
.ag-date .d{font-size:26px;font-weight:800;line-height:1}
.ag-date .m{font-size:11px;color:var(--mut);text-transform:uppercase}
.ag-date.today .d{color:var(--ac)}
.ag-evs{flex:1;display:flex;flex-direction:column;gap:7px;min-width:0}
.ag-ev{display:flex;gap:12px;align-items:center;background:var(--card);border:1px solid var(--line);border-left:3px solid var(--c);border-radius:10px;padding:9px 12px;cursor:pointer}
.ag-ev .tm{font-variant-numeric:tabular-nums;color:var(--mut);font-size:12.5px;min-width:46px}
.ag-ev .ti{font-weight:600}
.ag-ev .lo{color:var(--mut);font-size:12.5px}
.ag-empty{text-align:center;color:var(--mut);padding:70px 20px}
.ag-empty .e{font-size:48px}

/* ----------------------------- MODALS ----------------------------- */
.modal-root{position:fixed;inset:0;z-index:50;display:grid;place-items:center;padding:18px}
.scrim{position:absolute;inset:0;background:rgba(5,9,22,.62);backdrop-filter:blur(3px)}
.sheet{position:relative;background:var(--panel);border:1px solid var(--line-2);border-radius:18px;box-shadow:var(--shadow);
  width:100%;max-width:520px;max-height:90vh;overflow:auto;animation:pop .18s ease}
@keyframes pop{from{transform:translateY(10px) scale(.98);opacity:0}to{transform:none;opacity:1}}
.sheet-h{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 6px}
.sheet-h h3{margin:0;font-size:18px}
.sheet-b{padding:8px 20px 20px;display:flex;flex-direction:column;gap:14px}
.field{display:flex;flex-direction:column;gap:6px}
.field>label{font-size:12px;font-weight:600;color:var(--mut)}
.inp,select.inp,textarea.inp{background:var(--panel-2);border:1px solid var(--line-2);color:var(--ink);border-radius:10px;padding:11px 12px;outline:none;width:100%}
.inp:focus{border-color:var(--ac)}
textarea.inp{resize:vertical;min-height:64px}
.row{display:flex;gap:10px}.row>*{flex:1}
.row.tight{gap:8px;align-items:center}
.titlein{font-size:17px;font-weight:600;border:none;border-bottom:2px solid var(--line-2);border-radius:0;background:none;padding:8px 2px}
.titlein:focus{border-color:var(--ac)}
.seg{display:flex;background:var(--panel-2);border:1px solid var(--line-2);border-radius:10px;padding:2px;width:max-content}
.seg button{background:none;border:none;color:var(--mut);padding:7px 14px;border-radius:8px;font-weight:600;font-size:13px}
.seg button.on{background:var(--ac);color:#fff}
.swatches{display:flex;gap:8px;flex-wrap:wrap}
.sw{width:26px;height:26px;border-radius:50%;border:2px solid transparent;cursor:pointer}
.sw.on{border-color:var(--ink);box-shadow:0 0 0 2px var(--panel)}
.chips{display:flex;flex-wrap:wrap;gap:7px}
.chip{background:var(--panel-2);border:1px solid var(--line-2);color:var(--ink);border-radius:99px;padding:6px 12px;font-size:12.5px;display:flex;align-items:center;gap:6px}
.chip.on{background:var(--ac);border-color:var(--ac);color:#fff}
.chip .x{cursor:pointer;opacity:.8}
.guest-list{display:flex;flex-direction:column;gap:6px}
.guest{display:flex;align-items:center;gap:8px;font-size:13px}
.guest .st{font-size:11px;color:var(--mut);margin-left:auto}
.sheet-f{display:flex;gap:10px;align-items:center;padding:14px 20px;border-top:1px solid var(--line);position:sticky;bottom:0;background:var(--panel)}
.btn{border:none;border-radius:11px;padding:11px 18px;font-weight:700;font-size:14px}
.btn.primary{background:var(--grad);color:#fff}
.btn.ghost{background:var(--panel-2);border:1px solid var(--line-2);color:var(--ink)}
.btn.danger{background:none;color:var(--danger)}
.btn:hover{filter:brightness(1.05)}
.muted{color:var(--mut);font-size:12.5px}
.plus-tag{font-size:10px;font-weight:800;letter-spacing:.04em;background:linear-gradient(135deg,#ffb020,#ff7a3d);color:#1a1205;padding:2px 7px;border-radius:99px;vertical-align:middle}
.note{background:color-mix(in srgb,var(--ac) 10%,transparent);border:1px solid color-mix(in srgb,var(--ac) 30%,transparent);
  border-radius:10px;padding:10px 12px;font-size:12.5px;color:var(--ink)}
.share-url{display:flex;gap:8px}.share-url .inp{font-size:12px}
.detail .dl{display:flex;gap:10px;align-items:flex-start;font-size:14px;padding:4px 0}
.detail .dl .ic{width:20px;text-align:center;color:var(--mut)}
.cbar{height:5px;border-radius:99px;background:var(--c);margin-bottom:4px}

/* notifications panel */
.notif-pop{position:absolute;top:56px;right:60px;width:330px;max-height:60vh;overflow:auto;background:var(--panel);
  border:1px solid var(--line-2);border-radius:14px;box-shadow:var(--shadow);z-index:40}
.notif-pop h4{margin:0;padding:14px 16px 8px;font-size:14px}
.notif-item{padding:10px 16px;border-top:1px solid var(--line);font-size:13px}
.notif-item.un{background:color-mix(in srgb,var(--ac) 8%,transparent)}
.notif-item b{display:block;margin-bottom:2px}
.notif-item .tm{color:var(--mut);font-size:11px;margin-top:3px}
.notif-empty{padding:28px 16px;text-align:center;color:var(--mut)}

.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);background:var(--ink);color:var(--bg);
  padding:11px 18px;border-radius:12px;font-weight:600;font-size:13.5px;z-index:80;box-shadow:var(--shadow);animation:pop .2s}

/* ----------------------------- RESPONSIVE ----------------------------- */
@media(max-width:880px){
  #app{grid-template-columns:1fr}
  .side{position:fixed;left:0;top:0;bottom:0;width:84%;max-width:320px;z-index:30;transform:translateX(-102%);transition:transform .22s ease}
  body.side-open .side{transform:none}
  .side-close{display:grid}
  .side-scrim{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:25}
  body.side-open .side-scrim{display:block}
  .only-mobile{display:grid}
  .search-box{display:none}
  .period{font-size:15px}
  .views button{padding:7px 9px;font-size:12px}
  .notif-pop{right:10px;left:10px;width:auto}
}
@media(max-width:560px){
  .views [data-view]{font-size:0;padding:8px}
  .views [data-view]::first-letter{font-size:13px}
  .views button::after{font-size:13px}
  .topbar{gap:6px;padding:10px 12px}
}
