/* ============================================================
   calendar.css — 1 sections
   ============================================================ */

/* ============================================================
   CALENDAR — OUTLOOK STYLE
============================================================ */
.cal-outer { display:flex; gap:0; overflow:hidden; border:1px solid var(--border); border-radius:12px; }

/* Left panel — mini-cal + legend */
.cal-left {
  width:210px; flex-shrink:0; background:var(--bg3);
  border-right:1px solid var(--border); display:flex; flex-direction:column;
  overflow-y:auto; min-height:0; align-self:stretch;
}
.cal-mini { padding:14px 12px; flex-shrink:0; }
.cal-mini-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:10px; }
.cal-mini-title { font-size:13px; font-weight:800; color:var(--text); font-family:"Barlow Condensed",sans-serif; }
.cal-mini-nav { background:none; border:none; color:var(--text3); cursor:pointer; font-size:14px; padding:2px 5px; border-radius:4px; }
.cal-mini-nav:hover { background:var(--bg4); color:var(--text); }
.cal-mini-grid { display:grid; grid-template-columns:repeat(7,1fr); gap:1px; }
.cal-mini-dh { font-size:8px; font-weight:700; color:var(--text3); text-align:center; padding:2px 0; text-transform:uppercase; }
.cal-mini-d  { font-size:11px; text-align:center; padding:3px 2px; border-radius:50%; cursor:pointer; color:var(--text2); line-height:1.4; aspect-ratio:1; display:flex; align-items:center; justify-content:center; }
.cal-mini-d:hover { background:var(--bg4); color:var(--text); }
.cal-mini-d.has-event { font-weight:700; color:var(--text); }
.cal-mini-d.today-mini { background:var(--red); color:#fff !important; font-weight:700; }
.cal-mini-d.selected-mini { background:rgba(183,28,28,.2); color:var(--red); font-weight:700; }
.cal-mini-d.other-m { color:var(--text3); opacity:.4; }
.cal-legend { padding:12px 14px; border-top:1px solid var(--border); }
.cal-legend-title { font-size:9px; font-weight:700; color:var(--text3); text-transform:uppercase; letter-spacing:1px; margin-bottom:8px; }
.cal-legend-item { display:flex; align-items:center; gap:7px; font-size:11px; color:var(--text2); padding:4px 0; cursor:pointer; border-radius:5px; transition:background .1s; padding:4px 6px; margin:0 -6px; }
.cal-legend-item:hover { background:var(--bg4); }
.cal-legend-dot { width:10px; height:10px; border-radius:3px; flex-shrink:0; }
.cal-legend-item.active { font-weight:700; color:var(--text); }

/* Right area — toolbar + main grid */
.cal-right { flex:1; display:flex; flex-direction:column; overflow:hidden; background:var(--bg2); min-height:0; }
.cal-toolbar { display:flex; align-items:center; gap:8px; padding:10px 14px; border-bottom:1px solid var(--border); flex-wrap:wrap; background:var(--bg2); }
.cal-nav-btn { background:var(--bg3); border:1px solid var(--border); color:var(--text); border-radius:6px; padding:5px 12px; font-size:14px; font-weight:700; cursor:pointer; line-height:1; transition:background .12s; }
.cal-nav-btn:hover { background:var(--bg4); }
.cal-today-btn { background:none; border:1px solid var(--border); color:var(--text2); border-radius:6px; padding:5px 12px; font-size:12px; font-weight:600; cursor:pointer; }
.cal-today-btn:hover { border-color:var(--red); color:var(--red); }
.cal-month-label { font-size:18px; font-weight:900; color:var(--text); font-family:"Barlow Condensed",sans-serif; flex:1; padding:0 6px; }
.cal-view-toggle { display:flex; border:1px solid var(--border); border-radius:6px; overflow:hidden; }
.cal-view-btn { padding:5px 14px; font-size:12px; font-weight:700; cursor:pointer; color:var(--text3); border:none; background:var(--bg3); border-right:1px solid var(--border); }
.cal-view-btn:last-child { border-right:none; }
.cal-view-btn.active { background:var(--red); color:#fff; }
.cal-add-btn { background:var(--red); border:none; color:#fff; border-radius:6px; padding:6px 14px; font-size:12px; font-weight:700; cursor:pointer; white-space:nowrap; }
.cal-add-btn:hover { opacity:.88; }

/* Month grid */
.cal-month { flex:1; display:grid; grid-template-columns:repeat(7,1fr); overflow-y:auto; min-height:0; grid-auto-rows:min-content; align-content:start; }
.cal-dh { background:var(--bg3); padding:8px 12px; font-size:10px; font-weight:700; color:var(--text3); text-transform:uppercase; letter-spacing:.5px; border-bottom:2px solid var(--border); position:sticky; top:0; z-index:1; text-align:left; }
.cal-cell { background:var(--bg2); border-right:1px solid var(--border); border-bottom:1px solid var(--border); padding:6px 8px; min-height:110px; cursor:pointer; transition:background .1s; vertical-align:top; position:relative; }
.cal-cell:hover { background:var(--bg3); }
.cal-cell.today { background:rgba(183,28,28,.04); }
.cal-cell.sel-cell { background:rgba(183,28,28,.09); }
.cal-cell.other { opacity:.45; }
.cal-cell:nth-child(7n) { border-right:none; }
.cal-num { font-size:13px; font-weight:700; color:var(--text2); display:inline-flex; align-items:center; justify-content:center; width:26px; height:26px; border-radius:50%; margin-bottom:5px; }
.cal-num.today-n { background:var(--red); color:#fff; }
.cal-block { display:block; font-size:10px; font-weight:600; padding:2px 7px; border-radius:3px; margin-bottom:2px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; cursor:pointer; line-height:1.5; border-left:3px solid; }
.cal-block:hover { opacity:.85; }
.cal-more-lnk { font-size:10px; color:var(--text3); font-weight:700; cursor:pointer; padding:1px 0; }
.cal-more-lnk:hover { color:var(--red); }

/* Week grid */
.cal-week-wrap { flex:1; display:flex; flex-direction:column; overflow:hidden; min-height:0; }
.cal-week-head { display:grid; grid-template-columns:56px repeat(7,1fr); border-bottom:1px solid var(--border); background:var(--bg3); flex-shrink:0; }
.cal-week-dh { padding:8px 6px; text-align:center; border-right:1px solid var(--border); }
.cal-week-dh:last-child { border-right:none; }
.cal-wdl { font-size:9px; font-weight:700; color:var(--text3); text-transform:uppercase; }
.cal-wdn { font-size:20px; font-weight:900; color:var(--text); line-height:1; display:inline-flex; align-items:center; justify-content:center; width:32px; height:32px; border-radius:50%; }
.cal-wdn.today-w { background:var(--red); color:#fff; }
.cal-week-body { flex:1; overflow-y:auto; display:grid; grid-template-columns:56px repeat(7,1fr); grid-auto-rows:52px; min-height:0; }
.cal-tl { background:var(--bg3); border-right:1px solid var(--border); font-size:9px; color:var(--text3); text-align:right; padding:4px 8px 0; border-bottom:1px solid var(--border); position:sticky; left:0; }
.cal-wc { background:var(--bg2); border-right:1px solid var(--border); border-bottom:1px solid var(--border); min-height:52px; padding:2px 3px; cursor:pointer; transition:background .1s; position:relative; }
.cal-wc:hover { background:var(--bg3); }
.cal-wc:last-child { border-right:none; }
.cal-we { display:block; font-size:9px; font-weight:600; padding:2px 5px; border-radius:3px; margin-bottom:2px; line-height:1.4; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; border-left:3px solid; cursor:pointer; }
.cal-we:hover { opacity:.85; }

/* Day detail panel */
.cal-day-detail { border-top:1px solid var(--border); padding:12px 16px; background:var(--bg2); flex-shrink:0; max-height:220px; overflow-y:auto; }
.cal-dd-title { font-size:13px; font-weight:800; color:var(--text); margin-bottom:10px; display:flex; align-items:center; justify-content:space-between; }
.cal-ev-row { display:flex; align-items:center; gap:10px; padding:7px 10px; border-radius:8px; border:1px solid; margin-bottom:6px; cursor:pointer; transition:opacity .12s; }
.cal-ev-row:hover { opacity:.85; }

/* CAROUSEL */
.lp-carousel-wrap { max-width:1200px; margin:0 auto; padding:0 40px 48px; }
.lp-carousel { position:relative; overflow:hidden; border-radius:20px; width:100%; }
.lp-carousel-track { display:flex; width:100%; transition:transform .5s cubic-bezier(.4,0,.2,1); will-change:transform; }
.lp-carousel-slide { min-width:100%; width:100%; flex-shrink:0; position:relative; cursor:pointer; height:320px; overflow:hidden; }
.lp-carousel-dots { display:flex; justify-content:center; gap:6px; margin-top:14px; }
.lp-carousel-dot { width:8px; height:8px; border-radius:50%; background:var(--border); border:none; cursor:pointer; transition:all .25s; padding:0; }
.lp-carousel-dot.active { width:24px; border-radius:4px; background:var(--red); }
.lp-carousel-nav { position:absolute; top:50%; transform:translateY(-50%); background:rgba(0,0,0,.55); border:none; color:#fff; width:40px; height:40px; border-radius:50%; cursor:pointer; font-size:18px; display:flex; align-items:center; justify-content:center; z-index:10; transition:background .2s; }
.lp-carousel-nav:hover { background:rgba(0,0,0,.85); }
.lp-carousel-nav.prev { left:14px; }
.lp-carousel-nav.next { right:14px; }
@media(max-width:768px){ .lp-carousel-wrap { padding:0 12px 32px; } }

/* FOOTER */
/* FOOTER */
.lp-footer {
  padding:40px; display:flex; justify-content:space-between; align-items:center;
  border-top:1px solid var(--border); font-size:12px; color:var(--text3);
  flex-wrap:wrap; gap:12px;
}

/* RESPONSIVE */
@media (max-width:900px) {
  /* NAV */
  .lp-nav { padding:0 16px; height:54px; }
  .lp-nav-logo { font-size:17px; }
  .lp-nav-logo .nmark { width:30px; height:30px; font-size:12px; }
  .lp-desktop-only { display:none !important; }
  .lp-burger { display:flex !important; }

  /* HERO */
  .lp-hero-content {
    grid-template-columns:1fr !important;
    padding:24px 16px 20px !important;
    gap:20px !important;
  }
  .lp-auth-card { order:-1; }
  .lp-hero-title { font-size:clamp(36px,10vw,56px); }
  .lp-hero-sub { font-size:14px; }
  .lp-features-row { gap:6px; }
  .lp-feat-pill { font-size:11px; padding:5px 10px; }

  /* CAROUSEL */
  #lp-comps-section { padding:16px 16px 24px; }
  .lp-comp-card { width:175px; }

  /* PROPS */
  .lp-section > div[style*="repeat(4"] { grid-template-columns:1fr 1fr !important; }
  .lp-news { grid-template-columns:1fr; }
  .lp-news-card.featured { grid-column:span 1; }
  .lp-section { padding:40px 16px; }
  .lp-ad { margin:0 16px; padding:14px 16px; }
  .lp-devise { padding:40px 16px; }
  .lp-devise > div > div[style*="grid-template-columns:1fr 1fr"] { grid-template-columns:1fr !important; }
  .lp-br-desktop { display:none; }
  .lp-footer { padding:24px 16px; }

  /* AUTH CARD */
  .lp-auth-card { padding:20px; }
  .auth-role { grid-template-columns:1fr 1fr 1fr; gap:6px; }
  .auth-role-btn { padding:8px 4px; }
  .auth-role-btn .ri { font-size:16px; }
  .auth-role-btn .rn { font-size:10px; }
  .auth-role-btn .rs { display:none; }
}

@media (max-width:480px) {
  .lp-section > div[style*="repeat(4"] { grid-template-columns:1fr !important; }
  .lp-devise-text { font-size:clamp(22px,7vw,40px); }
  .lp-hero-title { font-size:clamp(32px,11vw,48px); }
  #lp-comps-section > div:first-child { flex-direction:column; align-items:flex-start; gap:6px; }
}

/* LOGIN ERROR */
.login-error {
  background:rgba(183,28,28,.15); border:1px solid rgba(183,28,28,.3);
  border-radius:8px; padding:10px 14px; font-size:12px; color:#EF5350;
  margin-bottom:14px; display:none;
}


