:root{--font-sans:'Nunito',system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans";--fs-300:.8125rem;--fs-400:.9375rem;--fs-500:1.125rem;--fs-600:1.25rem;--fs-700:1.5rem;--fs-800:1.75rem;--radius:8px;--radius-sm:8px;--radius-md:12px;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--color-bg-light:#f9fafb;--color-muted:#6b7280;--color-success:#16a34a;--color-danger:#dc2626;--color-info:#0284c7;--c-bg:#fff;--c-surface:#fafbfc;--c-surface-strong:#eef1f6;--c-text:#0f172a;--c-muted:#6b7280;--c-border:#e5e7eb;--c-border-strong:#d1d5db;--c-primary:#2563eb;--c-primary-contrast:#fff;--c-success:#16a34a;--c-danger:#dc2626;--c-warning:#d97706;--c-info:#0284c7;--shadow-1:0 1px 2px rgba(16,24,40,.06);--shadow-2:0 2px 6px rgba(16,24,40,.06);--container-max:1280px;--sidebar-width:280px;--gutter-x:var(--space-6)}
*,*::before,*::after{box-sizing:border-box}
html,body{height:100%;margin:0;background:var(--c-bg);color:var(--c-text);font:400 var(--fs-400)/1.5 var(--font-sans);overflow-x:clip}
.app{min-height:100vh;overflow-x:clip}
.app__aside{background:var(--c-surface);border-right:1px solid var(--c-border);position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-width);overflow-y:auto;overflow-x:hidden}
.brand{display:flex;align-items:center;justify-content:center;padding:var(--space-8) var(--gutter-x);font-weight:700;border-bottom:1px solid var(--c-border)}
.menu{padding:0 var(--gutter-x) var(--space-6)}
.menu__section{position:relative;margin:var(--space-5) var(--space-2) var(--space-3);padding-bottom:var(--space-2);color:var(--c-text);font-size:var(--fs-500);font-weight:700;letter-spacing:-.02em;border-bottom:1px solid var(--c-border)}
.menu__section::after{content:'';position:absolute;bottom:-1px;left:0;width:40px;height:1px;background:var(--c-primary)}
.menu__item{display:flex;align-items:center;gap:.6rem;padding:.55rem .75rem;text-decoration:none;color:inherit;border-radius:var(--radius-sm)}
.menu__item:hover{background:#eef2ff}
.menu__item.is-active{background:#e8edff46;border:1px solid #dbe3ff}
/* Submenu items */
.menu__item.menu__sub{padding-left:1.5rem;font-size:calc(var(--fs-400) - 1px);opacity:.95}
.menu__item.menu__sub .fa{opacity:.9}
.app__main{display:flex;flex-direction:column;margin-left:var(--sidebar-width);min-width:0}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-3) 0;border-bottom:1px solid var(--c-border);background:#fff;position:sticky;top:0;z-index:50;box-shadow:0 1px 0 var(--c-border),0 6px 16px rgba(16,24,40,.04)}
.topbar > *{min-width:0}
.topbar .breadcrumbs{margin-left:var(--gutter-x);min-width:0;flex:1 1 auto}
.topbar .topbar__right{margin-right:var(--gutter-x)}
.topbar__right{display:flex;gap:var(--space-3);align-items:center;min-width:0;flex:0 1 auto;flex-wrap:wrap;justify-content:flex-end}
.breadcrumbs{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap;color:var(--c-muted);font-size:.8rem;font-weight:600;min-width:0}
.breadcrumbs__item{display:inline-flex;align-items:center;min-width:0;max-width:100%}
.breadcrumbs a,.breadcrumbs__link,.breadcrumbs__current{color:inherit;text-decoration:none;display:inline-flex;align-items:center;gap:.35rem;background:var(--c-surface);border:1px solid var(--c-border);border-radius:999px;padding:.25rem .6rem;min-width:0;max-width:100%}
.breadcrumbs span{display:inline-flex;align-items:center;gap:.35rem;min-width:0;max-width:100%}
.breadcrumbs a:hover,.breadcrumbs__link:hover{text-decoration:underline}
.breadcrumbs .sep{font-size:.75rem;opacity:.55;margin:0 .15rem}
.module-context .topbar{box-shadow:0 1px 0 var(--c-border),0 10px 26px rgba(16,24,40,.05)}
.module-context .breadcrumbs--module{padding:0;border:none;border-radius:0;background:transparent;box-shadow:none}
.module-context .breadcrumbs--module .sep{margin:0;opacity:.32;color:#64748b}
.module-context .breadcrumbs--module .breadcrumbs__link,
.module-context .breadcrumbs--module .breadcrumbs__current{min-height:32px;padding:.32rem .68rem;border-color:transparent;background:transparent;color:#64748b;font-weight:700;text-decoration:none;transition:color .16s ease,border-color .16s ease,background .16s ease}
.module-context .breadcrumbs--module .breadcrumbs__link:hover{color:#0f172a;background:rgba(248,250,252,.95);border-color:rgba(148,163,184,.18);text-decoration:none}
.module-context .breadcrumbs--module .breadcrumbs__item.is-current .breadcrumbs__link,
.module-context .breadcrumbs--module .breadcrumbs__current{background:rgba(248,250,252,.98);border-color:rgba(148,163,184,.18);color:#0f172a}
.module-context .breadcrumbs--module .breadcrumbs__item:first-child .breadcrumbs__link{color:#475569}
.page-title{margin:0;font-size:2.25rem;font-weight:800;color:var(--c-text);letter-spacing:-.03em;line-height:1.1;overflow-wrap:anywhere}
.page-title i{display:none}
.page-head{margin-top:var(--space-4);margin-bottom:var(--space-6);display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);flex-wrap:wrap;position:relative;padding-bottom:var(--space-4);border-bottom:2px solid var(--c-border-strong)}
.page-head > *{min-width:0;max-width:100%}
.page-head::after{content:'';position:absolute;bottom:-2px;left:0;width:80px;height:2px;background:linear-gradient(90deg,var(--c-primary),var(--c-primary) 60%,transparent)}
/* Module-specific header adjustments */
.module-context .container{padding-top:var(--space-4)}
.module-context .page-head{margin-top:var(--space-4);margin-bottom:var(--space-5)}
.module-context .page-title{font-size:2rem;font-weight:800}
.module-context .page-title .title__sub{display:inline-block;margin-left:.5rem;color:var(--c-muted);font-weight:500;font-size:var(--fs-500)}
.page-head__actions{display:flex;gap:.5rem;flex-wrap:wrap;min-width:0;max-width:100%}
.container{width:100%;max-width:var(--container-max);margin:0 auto;padding:var(--space-6) var(--space-8);min-width:0}
/* Zmenšení horního odsazení obsahu, aby titulek nebyl tak nízko pod topbarem */
.app__main .container{padding-top:var(--space-4)}
@media (max-width:1024px){.container{padding-left:var(--space-6);padding-right:var(--space-6)}}
.grid-form{display:grid;grid-template-columns:1fr 360px;gap:var(--space-6)}
@media (max-width:1024px){.grid-form{grid-template-columns:1fr}}
.sticky{position:sticky;top:calc(64px + var(--space-6))}
.card{background:#fff;border:1px solid var(--c-border);border-radius:var(--radius-md);box-shadow:var(--shadow-1)}
.card--info{border-left:3px solid var(--c-info)}
.card__header{padding:.85rem 1rem;border-bottom:1px solid var(--c-border);font-weight:600;display:flex;gap:.6rem;align-items:center;min-width:0}
.card__body{padding:1rem;min-width:0}
.card+.card{margin-top:var(--space-6)}
.form-row{margin-bottom:1rem}
.form-row label{display:block;margin-bottom:.4rem;font-weight:600;font-size:var(--fs-400)}
.form-row input[type="text"],.form-row input[type="email"],.form-row input[type="number"],.form-row input[type="password"],.form-row select,.form-row textarea{width:100%;border:1px solid var(--c-border);border-radius:var(--radius-sm);padding:.55rem .7rem;background:#fff}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{outline:2px solid #93c5fd;outline-offset:2px}
.form-row small{display:block;margin-top:.4rem;color:var(--c-muted);font-size:var(--fs-300)}
.form-actions{display:flex;gap:.75rem;margin-top:1.5rem}
.form__row{display:grid;gap:var(--space-4)}
.form__group{display:grid;gap:.4rem}
.form__label{font-weight:600}
.form__control,.form__select,.form__textarea{width:100%;border:1px solid var(--c-border);border-radius:var(--radius-sm);padding:.55rem .7rem;background:#fff}
/* Konsolidace výšek ovládacích prvků podle design-systemu */
.form__control,.form__select{min-height:40px}
.form__select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%236b7280' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .7rem center;padding-right:2.25rem;min-width:120px}
.form__textarea{min-height:180px;resize:vertical}
.form__control:focus,.form__select:focus,.form__textarea:focus{outline:2px solid #93c5fd;outline-offset:2px}
.form__hint{color:var(--c-muted);font-size:var(--fs-300)}
.inline{display:flex;gap:.5rem;align-items:center}
.day-checkbox{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s ease}
.day-checkbox:hover{border-color:var(--c-primary);background:#f0f5ff}
.day-checkbox input[type="checkbox"]{margin:0;cursor:pointer}
.day-checkbox input[type="checkbox"]:checked + span{color:var(--c-primary);font-weight:600}
ul,ol{padding-left:1.5rem;margin:.5rem 0}
li{margin:.35rem 0;line-height:1.6}
.editor{border:1px solid var(--c-border);border-radius:var(--radius-sm);background:#fff}
.editor__toolbar{display:flex;align-items:center;gap:.25rem;flex-wrap:wrap;padding:.4rem;border-bottom:1px solid var(--c-border);background:var(--c-surface)}
.editor__btn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border:1px solid transparent;border-radius:6px;background:transparent;cursor:pointer}
.editor__btn:hover{background:#eef2ff;border-color:#dbe3ff}
.editor__content{min-height:220px;padding:.8rem}
.editor__sep{width:1px;height:24px;background:var(--c-border);margin:0 .25rem}
.tags{display:flex;gap:.4rem;flex-wrap:wrap}
.tag{display:inline-flex;align-items:center;gap:.4rem;padding:.25rem .55rem;background:#eef2ff;color:#1e40af;border:1px solid #c7d2fe;border-radius:999px;font-size:var(--fs-300)}
.tag .btn-x{border:none;background:transparent;cursor:pointer;line-height:1}
.tag-input{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center;border:1px solid var(--c-border);border-radius:var(--radius-sm);padding:.4rem .5rem;background:#fff}
.tag-input input{border:none;outline:none;min-width:120px;padding:.35rem}
.actions{display:flex;gap:.5rem;align-items:center;flex-wrap:nowrap}
@media (max-width:640px){.actions{flex-wrap:wrap}}
.btn{display:inline-flex;gap:.5rem;align-items:center;justify-content:center;border:1px solid var(--c-border);border-radius:var(--radius-sm);padding:.55rem .9rem;min-height:40px;background:#fff;color:#111;box-shadow:var(--shadow-1);text-decoration:none;font-size:var(--fs-400);line-height:1.5;cursor:pointer}
.btn--primary{background:var(--c-primary);border-color:var(--c-primary);color:var(--c-primary-contrast)}
.btn--primary:hover{filter:brightness(.98)}
.btn--subtle{background:#fff}
.btn--danger{background:#fee2e2;border-color:#fecaca;color:#7f1d1d}
.btn--icon{width:40px;height:40px;min-height:40px;display:grid;place-items:center;padding:0}
.btn--xs{padding:.35rem .55rem;min-height:32px;font-size:var(--fs-300)}
.btn-icon{border:none;background:transparent;cursor:pointer;padding:.25rem;line-height:1;transition:opacity .15s ease}
.btn-icon:hover{opacity:.7}
.btn-close{border:none;background:transparent;cursor:pointer;padding:.5rem;line-height:1;font-size:1.25rem;opacity:.6;transition:opacity .15s ease}
.btn-close:hover{opacity:1}
.switch{position:relative;display:inline-block;width:44px;height:26px}
.switch input{display:none}
.slider{position:absolute;cursor:pointer;inset:0;background:#e5e7eb;border-radius:999px;transition:.2s}
.slider:before{content:"";position:absolute;height:20px;width:20px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.2s;box-shadow:var(--shadow-1)}
.switch input:checked + .slider{background:#93c5fd}
.switch input:checked + .slider:before{transform:translateX(18px)}
.pill{display:inline-flex;align-items:center;gap:.4rem;padding:.2rem .55rem;border-radius:999px;border:1px solid;font-size:var(--fs-300);white-space:nowrap}
.pill--success{background:#ecfdf5;border-color:#a7f3d0;color:#065f46}
.pill--danger{background:#fef2f2;border-color:#fecaca;color:#7f1d1d}
.pill--published{background:#ecfdf5;border-color:#a7f3d0;color:#065f46}
.pill--draft{background:#f1f5f9;border-color:#cbd5e1;color:#334155}
.badge{display:inline-flex;align-items:center;gap:.35rem;padding:.2rem .5rem;border-radius:999px;border:1px solid var(--c-border);font-size:var(--fs-300);background:var(--c-surface);color:var(--c-text)}
.badge--success{background:#ecfdf5;border-color:#a7f3d0;color:#065f46}
.badge--warning{background:#fff7ed;border-color:#fed7aa;color:#7c2d12}
.badge--subtle{background:var(--c-surface);border-color:var(--c-border);color:var(--c-muted)}
.alert{padding:.6rem .75rem;border:1px solid;border-radius:var(--radius-sm)}
.alert--success{background:#ecfdf5;border-color:#a7f3d0;color:#065f46}
.alert--danger{background:#fef2f2;border-color:#fecaca;color:#7f1d1d}
.alert--info{background:#f0f9ff;border-color:#bae6fd;color:#075985}
.table-responsive{overflow-x:auto;max-width:100%}
.table{width:100%;border-collapse:collapse;border:1px solid var(--c-border);border-radius:var(--radius-sm);overflow:hidden}
.table th,.table td{padding:.75rem 1rem;border-bottom:1px solid var(--c-border);vertical-align:middle}
.table th{background:var(--c-surface);text-align:left;color:var(--c-muted);font-weight:600;font-size:var(--fs-300);text-transform:uppercase;letter-spacing:.03em}
.table tbody tr{background:#fff;transition:background-color .15s ease}
.table tbody tr:hover{background:var(--c-surface)}
.table tbody tr:last-child td{border-bottom:none}
.table .ta-right{text-align:right}
.table__actions{display:inline-flex;gap:.5rem;align-items:center;white-space:nowrap}
.table td:has(.table__actions){white-space:nowrap;width:1%}
.empty{text-align:center;color:var(--c-muted);padding:3rem;border:1px dashed var(--c-border);border-radius:var(--radius-md);background:#fff}
.pagination{display:flex;gap:.3rem;justify-content:flex-end}
.pagination a{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border:1px solid var(--c-border);border-radius:8px;text-decoration:none;color:inherit}
.pagination a.is-active{background:#e8edff;border-color:#dbe3ff}
.user-menu{position:relative}
.user-menu__trigger{display:flex;align-items:center;gap:.5rem;padding:.4rem .7rem;border:1px solid var(--c-border);border-radius:var(--radius-sm);background:#fff;cursor:pointer;font-family:inherit;font-size:var(--fs-400)}
.user-menu__trigger:hover{background:var(--c-surface)}
.user-menu__dropdown{position:absolute;right:0;top:calc(100% + .25rem);background:#fff;border:1px solid var(--c-border);border-radius:var(--radius-sm);box-shadow:var(--shadow-2);min-width:200px;opacity:0;visibility:hidden;transform:translateY(-8px);transition:opacity .2s ease,transform .2s ease,visibility .2s;z-index:100}
.user-menu:hover .user-menu__dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.user-menu__header{padding:.75rem 1rem;border-bottom:1px solid var(--c-border)}
.user-menu__name{font-weight:600;display:block}
.user-menu__email{font-size:var(--fs-300);color:var(--c-muted)}
.user-menu__item{display:flex;align-items:center;gap:.6rem;padding:.6rem 1rem;text-decoration:none;color:inherit;transition:background .15s}
.user-menu__item:hover{background:var(--c-surface)}
.user-menu__item--danger{color:var(--c-danger)}
.user-menu__item--danger:hover{background:#fef2f2}
.modal-backdrop{position:fixed;inset:0;background:rgba(2,6,23,.46);backdrop-filter:blur(10px) saturate(115%);-webkit-backdrop-filter:blur(10px) saturate(115%);z-index:1699;cursor:pointer;opacity:0;transition:opacity .28s ease}
.modal{position:fixed;inset:0;display:grid;place-items:center;z-index:1700;overflow-y:auto;overflow-x:hidden;padding:2rem 1rem;opacity:0;transition:opacity .28s ease}
/*.modal::before{content:"";position:absolute;left:50%;top:50%;width:min(720px,82vw);height:220px;transform:translate(-50%,calc(-50% + 120px));background:radial-gradient(ellipse at center,rgba(37,99,235,.34) 0%,rgba(37,99,235,.18) 34%,rgba(37,99,235,.08) 52%,rgba(37,99,235,0) 74%);filter:blur(26px);pointer-events:none;z-index:1700}
*/.modal__dialog{position:relative;z-index:1701;background:#fff;border:1px solid var(--c-border);border-radius:var(--radius-md);box-shadow:rgba(50,50,93,.25) 0 50px 100px -20px,rgba(0,0,0,.3) 0 30px 60px -30px,0 8px 24px rgba(15,23,42,.14);width:min(532px,90vw);max-height:88vh;display:flex;flex-direction:column;margin:auto;transform-origin:center center;will-change:transform,opacity;opacity:0;transform:translate3d(0,0,0) scale(.86);transition:transform .28s cubic-bezier(.18,.89,.32,1.16),opacity .24s ease,border-color .2s ease,box-shadow .2s ease;overflow:hidden}
.modal__dialog::before{content:"";position:absolute;left:1.1rem;right:1.1rem;top:0;height:2px;background:linear-gradient(90deg,rgba(255,255,255,0),rgba(255,255,255,.94) 18%,#ffffff 50%,rgba(255,255,255,.94) 82%,rgba(255,255,255,0));pointer-events:none;z-index:3;opacity:.95}
.modal__dialog::after{content:none}
.modal__header{padding:1.35rem 1.4rem 1.15rem;border-bottom:1px solid color-mix(in srgb,var(--c-border) 78%, #ffffff 22%);background:rgba(255,255,255,.96);box-shadow:inset 0 1px 0 rgba(255,255,255,.88);font-weight:600;flex-shrink:0;display:flex;align-items:center;gap:.5rem}
.modal__body{padding:1.35rem 1.4rem;overflow-y:auto;flex:1;min-width:0}
.modal__footer{padding:1.1rem 1.4rem 1.35rem;display:flex;justify-content:flex-end;gap:.5rem;border-top:1px solid var(--c-border);flex-shrink:0;min-width:0;flex-wrap:wrap}
.app--session-expired{overflow:hidden}
.app--offline-guard{overflow:hidden}
.session-expired-overlay{position:fixed;inset:0;z-index:1600;display:flex;align-items:center;justify-content:center;padding:clamp(1rem,2vw,2rem)}
.session-expired-overlay[hidden]{display:none !important}
.session-expired-overlay__backdrop{position:absolute;inset:0;background:rgba(15,23,42,.62);backdrop-filter:blur(8px)}
.session-expired-overlay__dialog{position:relative;z-index:1;width:min(680px,calc(100vw - 2rem));padding:clamp(1.4rem,2vw,2rem);border:1px solid rgba(255,255,255,.18);border-radius:24px;background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(248,250,252,.96));box-shadow:0 30px 80px rgba(15,23,42,.28)}
.session-expired-overlay__eyebrow{display:inline-flex;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.45rem .75rem;border:1px solid #dbe3ef;border-radius:999px;background:rgba(255,255,255,.72);font-size:.78rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#315ca8}
.session-expired-overlay__title{margin:0 0 .85rem;font-size:clamp(1.6rem,2.5vw,2.2rem);line-height:1.08;font-weight:900;letter-spacing:-.04em;color:#0f172a;max-width:14ch}
.session-expired-overlay__text{margin:0;max-width:56ch;font-size:1rem;line-height:1.65;color:#475569}
.session-expired-overlay__actions{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap;margin-top:1.5rem}
.session-expired-overlay__actions .btn{min-width:190px}
.session-expired-overlay__preview-close{margin-top:1rem}
.offline-mode-overlay{position:fixed;inset:0;z-index:1590;display:flex;align-items:center;justify-content:center;padding:clamp(1rem,2vw,2rem)}
.offline-mode-overlay[hidden]{display:none !important}
.offline-mode-overlay__backdrop{position:absolute;inset:0;background:radial-gradient(circle at top,rgba(14,116,144,.22),transparent 34%),rgba(15,23,42,.7);backdrop-filter:blur(9px)}
.offline-mode-overlay__dialog{position:relative;z-index:1;width:min(760px,calc(100vw - 2rem));padding:clamp(1.35rem,2vw,2.15rem);border:1px solid rgba(255,255,255,.16);border-radius:28px;background:linear-gradient(145deg,rgba(255,255,255,.98),rgba(241,245,249,.96));box-shadow:0 34px 90px rgba(15,23,42,.34);overflow:hidden}
.offline-mode-overlay__dialog::before{content:"";position:absolute;inset:auto -8% 72% auto;width:240px;height:240px;border-radius:999px;background:radial-gradient(circle,rgba(14,165,233,.22),transparent 70%);pointer-events:none}
.offline-mode-overlay__eyebrow{position:relative;display:inline-flex;align-items:center;gap:.55rem;margin-bottom:1rem;padding:.48rem .78rem;border:1px solid #cbd5e1;border-radius:999px;background:rgba(255,255,255,.78);font-size:.78rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#0f766e}
.offline-mode-overlay__title{position:relative;margin:0 0 .8rem;font-size:clamp(1.65rem,2.8vw,2.45rem);line-height:1.04;font-weight:900;letter-spacing:-.045em;color:#0f172a;max-width:13ch}
.offline-mode-overlay__text{position:relative;margin:0;max-width:58ch;font-size:1rem;line-height:1.68;color:#475569}
.offline-mode-overlay__panel{position:relative;display:grid;gap:.4rem;margin-top:1.25rem;padding:1rem 1.05rem;border:1px solid rgba(148,163,184,.24);border-radius:18px;background:linear-gradient(180deg,rgba(255,255,255,.9),rgba(248,250,252,.86))}
.offline-mode-overlay__panel-label{font-size:.76rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#0f766e}
.offline-mode-overlay__panel-value{font-size:1rem;font-weight:800;color:#0f172a}
.offline-mode-overlay__list{display:grid;gap:.45rem;margin-top:1.25rem;padding:0;list-style:none}
.offline-mode-overlay__list li{display:flex;align-items:flex-start;gap:.7rem;color:#334155;line-height:1.55}
.offline-mode-overlay__list i{margin-top:.15rem;color:#0f766e}
.offline-mode-overlay__actions{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap;margin-top:1.6rem}
.offline-mode-overlay__actions .btn{min-width:220px}
.offline-mode-overlay__meta{margin-top:1rem;font-size:.84rem;color:#64748b}
@media (max-width:640px){.session-expired-overlay__dialog{width:min(100vw - 1rem,680px);padding:1.1rem 1rem 1rem;border-radius:20px}.session-expired-overlay__actions{flex-direction:column;align-items:stretch}.session-expired-overlay__actions .btn,.session-expired-overlay__preview-close{width:100%}.session-expired-overlay__title{max-width:none}}
@media (max-width:640px){.offline-mode-overlay__dialog{width:min(100vw - 1rem,760px);padding:1.05rem 1rem 1rem;border-radius:22px}.offline-mode-overlay__actions{flex-direction:column;align-items:stretch}.offline-mode-overlay__actions .btn{width:100%;min-width:0}.offline-mode-overlay__title{max-width:none}}
.toasts{position:fixed;right:16px;bottom:16px;display:flex;flex-direction:column-reverse;gap:.5rem;z-index:2200;pointer-events:none}
@media (max-width:640px){.toasts{left:50%;right:auto;transform:translateX(-50%);width:min(96vw,520px)}}
.toast{display:flex;align-items:flex-start;gap:.75rem;background:#fff;color:var(--c-text);padding:.85rem 1rem;border-radius:var(--radius-sm);box-shadow:0 4px 12px rgba(16,24,40,.12),0 1px 3px rgba(16,24,40,.08);border:1px solid var(--c-border-strong);min-width:280px;max-width:420px;overflow:hidden;pointer-events:auto}
.toast__icon{flex:0 0 auto;display:grid;place-items:center;width:24px;height:24px;border-radius:999px;font-size:.875rem}
.toast__content{flex:1 1 auto}
.toast__title{font-weight:700;font-size:.9375rem;line-height:1.3;margin-bottom:.2rem}
.toast__message{font-size:.875rem;line-height:1.5;color:var(--c-muted)}
.toast__action{flex:0 0 auto;margin-left:.5rem;border:none;background:transparent;color:var(--c-primary);cursor:pointer;font-weight:600;font-size:.875rem;padding:.25rem .5rem;border-radius:4px;transition:background .15s}
.toast__action:hover{background:var(--c-surface)}
.toast--success{border-left:4px solid var(--c-success)}
.toast--success .toast__icon{color:var(--c-success);background:rgba(22,163,74,.1)}
.toast--error{border-left:4px solid var(--c-danger)}
.toast--error .toast__icon{color:var(--c-danger);background:rgba(220,38,38,.1)}
.toast--info{border-left:4px solid var(--c-info)}
.toast--info .toast__icon{color:var(--c-info);background:rgba(2,132,199,.1)}
@keyframes toast-in{from{opacity:0;transform:translateY(12px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes toast-out{from{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(12px) scale(.95)}}
.toast--enter{animation:toast-in .22s cubic-bezier(.175,.885,.32,1.1) forwards}
.toast--leave{animation:toast-out .18s ease-in forwards}
@media (prefers-reduced-motion:reduce){.modal,.modal-backdrop,.modal__dialog,.toast,.toast--enter,.toast--leave{transition:none !important;animation:none !important}}
.footer{text-align:center;padding:var(--space-8) var(--space-6);color:var(--c-muted);font-size:var(--fs-300);border-top:1px solid var(--c-border);background:var(--c-surface);margin-top:var(--space-8)}
.page-tree{border:1px solid var(--c-border);border-radius:var(--radius-sm);background:#fff;max-height:480px;overflow-y:auto;padding:.5rem}
.page-tree__item{display:flex;align-items:center;gap:.4rem;padding:.4rem .5rem;border-radius:6px;transition:background .15s}
.page-tree__item:hover{background:var(--c-surface)}
.page-tree__item[data-level="1"]{padding-left:1.5rem}
.page-tree__item[data-level="2"]{padding-left:3rem}
.page-tree__item[data-level="3"]{padding-left:4.5rem}
.page-tree__item[data-level="4"]{padding-left:6rem}
.page-tree__toggle{border:none;background:transparent;cursor:pointer;width:20px;height:20px;display:grid;place-items:center;padding:0;color:var(--c-muted);transition:transform .15s}
.page-tree__toggle i{font-size:.7rem}
.page-tree__toggle.is-expanded{transform:rotate(90deg)}
.page-tree__spacer{width:20px;height:20px;display:inline-block}
.page-tree__title{flex:1 1 auto;font-size:.9375rem}
.page-tree__perms{display:flex;gap:.25rem;align-items:center}
.page-tree__checkbox{display:inline-flex;cursor:pointer;position:relative}
.page-tree__checkbox input{position:absolute;opacity:0;pointer-events:none}
.page-tree__checkbox span{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--c-border);border-radius:6px;background:#fff;color:var(--c-muted);transition:all .15s}
.page-tree__checkbox span i{font-size:.8rem}
.page-tree__checkbox:hover span{background:var(--c-surface);border-color:var(--c-border-strong)}
.page-tree__checkbox input:checked + span{background:#e8edff;border-color:#93c5fd;color:var(--c-primary)}
.page-tree__checkbox--inherit input:checked + span{background:#f0fdf4;border-color:#86efac;color:#16a34a}
.page-tree__children{display:none}
.page-tree__children.is-expanded{display:block}
/* ========================================
   RESPONSIVE BREAKPOINTS
   Mobile: < 640px
   Tablet: 640px - 1024px
   Desktop: > 1024px
   ======================================== */

/* Tablet & Mobile: Sidebar jako overlay */
@media (max-width: 1024px) {
  .app__aside {
    position: fixed;
    left: 0;
    top: 0;
    bottom: 0;
    width: 280px;
    z-index: 1001;
    transform: translateX(-100%);
    transition: transform .3s cubic-bezier(.4,0,.2,1);
    box-shadow: 4px 0 24px rgba(16,24,40,.15);
  }
  .app__aside.is-open {
    transform: translateX(0);
  }
  .sidebar-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(16,24,40,.4);
    z-index: 1000;
    backdrop-filter: blur(2px);
  }
  .sidebar-overlay.is-active {
    display: block;
  }
  .app__main {
    margin-left: 0;
  }
  .topbar {
    position: fixed;
    left: 0;
    right: 0;
    width: 100%;
    isolation: isolate;
  }
  .topbar + * {
    margin-top: 84px;
  }
  .module-context .topbar + * {
    margin-top: 162px;
  }
  .topbar .breadcrumbs {
    margin-left: 0;
    flex: 1;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }

  .app__aside::-webkit-scrollbar-track {
    background: transparent;
  }

  .app__aside::-webkit-scrollbar-thumb {
    background: rgba(255,255,255,.22);
    border-radius: 999px;
    border: 2px solid transparent;
    background-clip: padding-box;
  }

  .app__aside::before,
  .app__aside::after {
    content: '';
    position: absolute;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.10);
    pointer-events: none;
    z-index: -1;
  }

  .app__aside::before {
    width: 420px;
    height: 420px;
    right: -110px;
    top: -120px;
    background: radial-gradient(circle, rgba(255,255,255,.08), rgba(255,255,255,.01) 62%, transparent 72%);
  }

  .app__aside::after {
    width: 280px;
    height: 280px;
    left: -80px;
    bottom: -60px;
    background: radial-gradient(circle, rgba(125,211,252,.14), rgba(255,255,255,.02) 68%, transparent 75%);
  }
  .topbar .breadcrumbs::-webkit-scrollbar {
    display: none;
  }
  .topbar .topbar__right {
    margin-right: 0;
    gap: var(--space-2);
  }
  
  /* Topbar tlačítka - skrýt text na menších zařízeních */
  .topbar-btn__text {
    display: none;
  }
  .topbar-btn {
    width: 44px;
    padding: 0;
    justify-content: center;
  }
  .topbar-btn i {
    margin: 0;
  }
  
  /* Hamburger tlačítko */
  .sidebar-toggle {
    display: flex !important;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    padding: 0;
    background: transparent;
    border: none;
    color: var(--c-primary);
    font-size: 1.5rem;
    cursor: pointer;
    border-radius: var(--radius-sm);
    transition: background .2s ease;
  }
  .sidebar-toggle:hover {
    background: var(--c-surface);
  }
  .sidebar-toggle:active {
    background: var(--c-border);
  }
  
  /* Container menší paddingy */
  .container {
    padding: var(--space-4) var(--space-5);
  }
  .app__main .container {
    padding-top: var(--space-3);
  }
  
  /* Page head úpravy */
  .page-head {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-4);
    margin-bottom: var(--space-5);
  }
  .page-head__actions {
    width: 100%;
    justify-content: flex-start;
  }
  
  /* Page title menší */
  .page-title {
    font-size: 1.75rem;
  }
  .module-context .page-title {
    font-size: 1.5rem;
  }
  
  /* Gridy na 1 sloupec */
  .grid-form {
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }
  
  /* Karty */
  .card {
    border-radius: var(--radius-sm);
  }
  .card__header {
    padding: .75rem;
    font-size: var(--fs-400);
  }
  .card__body {
    padding: .75rem;
  }
  .card + .card {
    margin-top: var(--space-4);
  }
  

  
  /* Formuláře */
  .form-row,
  .form__row {
    gap: var(--space-3);
  }
  .form__group {
    margin-bottom: var(--space-3);
  }
  .form__control,
  .form__select,
  .form__textarea {
    font-size: 1rem;
    padding: .65rem .75rem;
    min-height: 44px;
  }
  .form__select {
    min-height: 44px;
  }
  
  /* Tlačítka větší pro dotyk */
  .btn {
    min-height: 44px;
    padding: .65rem 1rem;
    font-size: var(--fs-400);
    gap: .4rem;
  }
  .btn--xs {
    min-height: 36px;
    padding: .45rem .65rem;
    font-size: .8rem;
  }
  .btn--icon {
    width: 44px;
    height: 44px;
    min-height: 44px;
  }
  
  /* Actions stack na menších obrazovkách */
  .actions {
    flex-wrap: wrap;
    gap: var(--space-3);
  }
  
  /* Tabulky responzivní úpravy - horizontální scroll */
  .table-responsive {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    border-radius: var(--radius-sm);
    border: 1px solid var(--c-border);
    /* Scrollbar styling pro tablet */
    scrollbar-width: thin;
    scrollbar-color: var(--c-border) transparent;
  }
  .table-responsive::-webkit-scrollbar {
    height: 8px;
  }
  .table-responsive::-webkit-scrollbar-track {
    background: var(--c-surface);
    border-radius: 4px;
  }
  .table-responsive::-webkit-scrollbar-thumb {
    background: var(--c-border);
    border-radius: 4px;
  }
  .table-responsive::-webkit-scrollbar-thumb:hover {
    background: var(--c-border-strong);
  }
  .table-responsive .table {
    /* Tabulka může být širší než container */
    width: auto;
    min-width: 100%;
    max-width: none;
    margin-bottom: 0;
    font-size: .9rem;
  }
  .table th,
  .table td {
    padding: .65rem .75rem;
    font-size: .9rem;
    white-space: nowrap;
  }
  .table th {
    font-size: .8rem;
  }
  .table__actions {
    display: inline-flex;
    gap: .4rem;
    flex-wrap: nowrap;
  }
  .table__actions .btn {
    padding: .45rem .65rem;
    font-size: .8rem;
    min-height: 36px;
    white-space: nowrap;
  }
  
  /* User menu */
  .user-menu__trigger {
    padding: .5rem .65rem;
    font-size: var(--fs-300);
  }
  
  /* Modals */
  .modal__dialog {
    width: min(540px, 92vw);
    margin: 1rem auto;
  }
  .modal {
    padding: 1rem 0;
  }
}

/* Mobile only: < 640px */
@media (max-width: 640px) {
  /* Root font-size menší pro lepší proporce */
  html {
    font-size: 14px;
  }
  
  /* Topbar ještě kompaktnější */
  .topbar {
    padding: .5rem .75rem;
  }
  .topbar + * {
    margin-top: 72px;
  }
  .module-context .topbar + * {
    margin-top: 72px;
  }
  
  /* Breadcrumbs zjednodušené */
  .breadcrumbs {
    font-size: .65rem;
    gap: .3rem;
  }
  .breadcrumbs a {
    padding: .15rem .4rem;
    font-size: .65rem;
  }
  .breadcrumbs .sep {
    font-size: .6rem;
  }
  
  /* Topbar right - skrytí textů */
  .topbar__right .btn span {
    display: none;
  }
  .topbar__right .user-menu__trigger .user-menu__avatar,
  .topbar__right .user-menu__trigger .user-menu__identity,
  .topbar__right .user-menu__trigger .user-menu__identity-name,
  .topbar__right .user-menu__trigger .user-menu__identity-email,
  .topbar__right .user-menu__trigger .user-menu__caret {
    display: inherit;
  }
  .topbar__right .user-menu__trigger .user-menu__identity {
    display: flex;
  }
  .topbar__right .btn i {
    margin: 0;
  }
  .topbar__right {
    gap: .35rem;
  }
  
  /* User menu kompaktní */
  .user-menu__trigger {
    width:auto;
    height:auto;
    padding:.4rem .55rem;
  }
  .user-menu__avatar{display:inline-flex}
  .user-menu__identity{display:flex}
  .user-menu__caret{display:inline-flex}
  
  /* Sidebar menší na mobilu */
  .app__aside {
    width: min(260px, 82vw);
  }
  .brand {
    padding: 1rem .75rem;
  }
  .menu {
    padding: 0 .75rem 1rem;
  }
  .menu__section {
    font-size: .7rem;
    margin: 1rem .25rem .5rem;
  }
  .menu__item {
    padding: .5rem .65rem;
    font-size: .85rem;
    gap: .5rem;
  }
  
  /* Container minimální paddingy */
  .container {
    padding: .75rem 1rem;
  }
  .app__main .container {
    padding-top: .5rem;
  }
  
  /* Page title ještě menší */
  .page-title {
    font-size: 1.35rem;
    line-height: 1.25;
  }
  .module-context .page-title {
    font-size: 1.2rem;
  }
  
  /* Page head */
  .page-head {
    margin-top: .5rem;
    margin-bottom: 1rem;
    padding-bottom: .75rem;
    gap: .75rem;
  }
  .page-head::after {
    width: 50px;
  }

  @media (max-width:1024px){
    .topbar .breadcrumbs,
    .breadcrumbs{
      display:none;
    }

    .user-menu__trigger{
      width:44px;
      min-width:44px;
      height:44px;
      padding:0;
      justify-content:center;
      gap:0;
    }

    .user-menu__trigger .user-menu__identity,
    .user-menu__trigger .user-menu__identity-name,
    .user-menu__trigger .user-menu__identity-email,
    .user-menu__trigger .user-menu__caret{
      display:none;
    }

    .user-menu__trigger .user-menu__avatar{
      display:inline-flex;
      margin:0;
    }
  }

  @media (max-width:1024px){
    .topbar .breadcrumbs,
    .breadcrumbs{
      display:none !important;
    }

    .topbar .topbar__right{
      margin-left:auto;
    }

    .user-menu__trigger{
      display:inline-flex !important;
      align-items:center !important;
      justify-content:center !important;
      width:44px !important;
      min-width:44px !important;
      max-width:44px !important;
      height:44px !important;
      min-height:44px !important;
      padding:0 !important;
      gap:0 !important;
      grid-template-columns:none !important;
      overflow:hidden;
    }

    .user-menu__trigger .user-menu__identity,
    .user-menu__trigger .user-menu__identity-name,
    .user-menu__trigger .user-menu__identity-email,
    .user-menu__trigger .user-menu__caret{
      display:none !important;
      width:0 !important;
      max-width:0 !important;
      overflow:hidden !important;
    }

    .user-menu__trigger .user-menu__avatar{
      display:inline-flex !important;
      flex:0 0 auto;
      margin:0 !important;
    }
  }
  
  /* Akce pod sebou */
  .page-head__actions {
    flex-direction: column;
    width: 100%;
  }
  .page-head__actions .btn {
    width: 100%;
    justify-content: center;
  }
  
  /* Karty minimální padding */
  .card {
    font-size: .9rem;
  }
  .card__header {
    padding: .6rem .7rem;
    font-size: .85rem;
  }
  .card__body {
    padding: .7rem;
  }
  .card + .card {
    margin-top: .75rem;
  }
  
  /* Tlačítka kompaktní na mobilech */
  .btn {
    font-size: .85rem;
    padding: .5rem .7rem;
    min-height: 38px;
    gap: .35rem;
  }
  .btn--xs {
    font-size: .75rem;
    padding: .35rem .5rem;
    min-height: 32px;
  }
  .btn--icon {
    width: 38px;
    height: 38px;
    min-height: 38px;
  }
  .topbar__right .btn {
    width: 38px;
    height: 38px;
    min-height: 38px;
    padding: 0;
    font-size: 1rem;
  }
  
  /* Tabulky - horizontální scroll na mobilu */
  .table-responsive {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    border-radius: var(--radius-sm);
    border: 1px solid var(--c-border);
    /* Scrollbar styling */
    scrollbar-width: thin;
    scrollbar-color: var(--c-border) transparent;
  }
  .table-responsive::-webkit-scrollbar {
    height: 6px;
  }
  .table-responsive::-webkit-scrollbar-track {
    background: transparent;
  }
  .table-responsive::-webkit-scrollbar-thumb {
    background: var(--c-border);
    border-radius: 3px;
  }
  .table-responsive::-webkit-scrollbar-thumb:hover {
    background: var(--c-border-strong);
  }
  .table-responsive .table {
    /* Tabulka může být širší než viewport */
    width: auto;
    min-width: 100%;
    max-width: none;
    margin-bottom: 0;
    font-size: .85rem;
    border-left: none;
    border-right: none;
  }
  .table th,
  .table td {
    padding: .6rem .7rem;
    font-size: .85rem;
    white-space: nowrap;
  }
  .table th {
    font-size: .8rem;
    padding: .55rem .7rem;
  }
  .table__actions {
    display: inline-flex;
    gap: .3rem;
    flex-wrap: nowrap;
  }
  .table__actions .btn {
    padding: .35rem .5rem;
    font-size: .75rem;
    min-height: 32px;
    white-space: nowrap;
  }
  
  /* Formuláře kompaktní */
  .form__control,
  .form__select,
  .form__textarea {
    font-size: .9rem;
    padding: .5rem .6rem;
    min-height: 38px;
  }
  .form__select {
    min-height: 38px;
  }
  .form__label {
    font-size: .85rem;
    margin-bottom: .3rem;
  }
  .form__hint {
    font-size: .75rem;
    margin-top: .3rem;
  }
  .form-actions {
    flex-direction: column;
    gap: .5rem;
    margin-top: 1rem;
  }
  .form-actions .btn {
    width: 100%;
    justify-content: center;
  }
  
  /* Alerts kompaktní */
  .alert {
    padding: .5rem .6rem;
    font-size: .8rem;
    line-height: 1.4;
  }
  
  /* Modals fullscreen na mobilu */
  .modal__dialog {
    width: 100%;
    max-width: 100%;
    height: 100vh;
    max-height: 100vh;
    margin: 0;
    border-radius: 0;
    font-size: .9rem;
  }
  .modal__header {
    padding: .75rem;
    font-size: .9rem;
  }
  .modal__body {
    padding: .75rem;
  }
  .modal__footer {
    padding: .75rem;
    gap: .4rem;
  }
  .modal {
    padding: 0;
  }
  
  /* Toast na mobilu */
  .toast {
    min-width: auto;
    max-width: 100%;
    font-size: .8rem;
    padding: .7rem .85rem;
  }
  .toast__title {
    font-size: .85rem;
  }
  .toast__message {
    font-size: .75rem;
  }
  
  /* Settings grid na mobilu */
  .settings-grid {
    grid-template-columns: 1fr;
    gap: .75rem;
  }
  
  /* Pagination na mobilu */
  .pagination {
    gap: .15rem;
    justify-content: center;
    flex-wrap: wrap;
  }
  .pagination a {
    width: 34px;
    height: 34px;
    font-size: .8rem;
  }
  
  /* Pills a badges menší */
  .pill {
    font-size: .65rem;
    padding: .15rem .4rem;
  }
  .badge {
    font-size: .65rem;
    padding: .15rem .35rem;
  }
  
  /* Empty state */
  .empty {
    padding: 2rem 1rem;
    font-size: .85rem;
  }
  
  /* Switch menší */
  .switch {
    width: 40px;
    height: 24px;
  }
  .slider:before {
    height: 18px;
    width: 18px;
  }
  .switch input:checked + .slider:before {
    transform: translateX(16px);
  }
}

/* Extra small screens: < 400px */
@media (max-width: 400px) {
  /* Ještě menší container padding */
  .container {
    padding: 0.5rem 0.75rem;
  }
  
  /* Card ještě kompaktnější */
  .card__body {
    padding: 0.5rem;
  }
  .card__header {
    padding: 0.5rem;
    font-size: 0.8rem;
  }
  
  /* Tlačítka na celou šířku v headerech */
  .card__header {
    flex-direction: column;
    align-items: flex-start !important;
  }
  .card__header form {
    width: 100%;
  }
  .card__header .btn {
    width: 100%;
    justify-content: center;
    font-size: 0.8rem;
    padding: 0.5rem;
  }
  
  /* Page title ještě menší */
  .page-title {
    font-size: 1.2rem;
  }
  
  /* Formuláře na celou šířku */
  .form__control,
  .form__select,
  .form__textarea {
    font-size: 0.85rem;
    padding: 0.45rem 0.5rem;
  }
  
  /* Alert kompaktnější */
  .alert {
    padding: 0.5rem;
    font-size: 0.8rem;
  }
}

/* Enhanced Select Styling */
.form__select {
    color: var(--c-text);
    cursor: pointer;
    transition: all 0.2s ease;
    background-color: #fff;
    background-size: 16px;
}

.form__select:hover {
    border-color: var(--c-border-strong);
    background-color: var(--c-surface);
}

.form__select:focus {
    outline: 2px solid #93c5fd;
    outline-offset: 2px;
    border-color: var(--c-primary);
    background-color: #fff;
}

/* Modal Responsive Adjustments */
@media (max-width: 1024px) {
    .modal__dialog {
        width: 95vw !important;
    }
    
    .form__row[style*="grid-template-columns"] {
        grid-template-columns: 1fr !important;
    }
}

/* Form Group in Modal */
.form__group {
    margin-bottom: 0;
}

/* Better checkbox styling */
.form__checkbox input[type="checkbox"] {
    width: 18px;
    height: 18px;
    cursor: pointer;
    accent-color: var(--c-primary);
}

/* Improved textarea */
.form__textarea {
    font-family: var(--font-sans);
    line-height: 1.6;
}

.form__textarea:focus {
    outline: 2px solid #93c5fd;
    outline-offset: 2px;
    border-color: var(--c-primary);
}

/* Upload Box - Drag & Drop */
.upload-box {
    position: relative;
    border: 2px dashed var(--c-border-strong);
    border-radius: var(--radius-md);
    background: var(--c-surface);
    padding: var(--space-6);
    text-align: center;
    transition: all 0.2s ease;
    cursor: pointer;
}

.upload-box:hover {
    border-color: var(--c-primary);
    background: #f0f5ff;
}

.upload-box.drag-over {
    border-color: var(--c-primary);
    background: #dbeafe;
    border-style: solid;
}

.upload-box__input {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    cursor: pointer;
}

.upload-box__placeholder {
    pointer-events: none;
}

.upload-box__preview {
  display: block;
  max-width: 100%;
  max-height: 240px;
  margin: 0 auto;
  border-radius: var(--radius-md);
  object-fit: contain;
}

/* ========================================
   2026 Admin visual refresh
   Inspired by the accounting module visual language.
   Centralized as an override layer for easy revert.
   ======================================== */

:root{
  --radius-lg:16px;
  --radius-xl:20px;
  --c-primary-soft:rgba(37,99,235,.08);
  --c-success-soft:rgba(5,150,105,.10);
  --c-warning-soft:rgba(217,119,6,.12);
  --c-danger-soft:rgba(225,29,72,.10);
  --c-slate-soft:rgba(71,85,105,.10);
  --shadow-3:0 8px 24px rgba(15,23,42,.05);
}

.topbar{
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(10px);
  box-shadow:0 1px 0 rgba(229,231,235,.9),0 8px 24px rgba(15,23,42,.04);
}

.app__aside{
  background:#fff;
  padding:.95rem 0 1rem;
  border-right-color:rgba(148,163,184,.16);
  box-shadow:10px 0 28px rgba(15,23,42,.055);
  scrollbar-width:thin;
  scrollbar-color:rgba(148,163,184,.32) transparent;
  isolation:isolate;
}

.app__aside::-webkit-scrollbar{width:10px}
.app__aside::-webkit-scrollbar-track{background:transparent}
.app__aside::-webkit-scrollbar-thumb{background:rgba(148,163,184,.32);border-radius:999px;border:2px solid transparent;background-clip:padding-box}

.app__aside::before,
.app__aside::after{
  content:'';
  position:absolute;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);
  pointer-events:none;
  z-index:-1;
}

/*.app__aside::before{
  width:420px;
  height:420px;
  right:-110px;
  top:-120px;
  background:radial-gradient(circle, rgba(191,219,254,.34), rgba(255,255,255,.01) 62%, transparent 72%);
}*/

.app__aside::after{
  width:280px;
  height:280px;
  left:-80px;
  bottom:1.1rem;
  background:radial-gradient(circle, rgba(96,165,250,.18), rgba(255,255,255,.02) 68%, transparent 75%);
}

.brand{
  justify-content:left;
  gap:.85rem;
  padding:.4rem 1.1rem 1.5rem 2rem;
  margin:0 0 .6rem;
  border:none;
  border-radius:0;
  background:transparent;
  position:relative;
  top:auto;
  z-index:auto;
  backdrop-filter:none;
  -webkit-backdrop-filter:none;
  box-shadow:none;
}

.brand > .brand__logo,
.brand img.brand__logo{
  height:90px !important;
  max-height:90px !important;
  max-width:240px !important;
  width:auto !important;
  display:block;
  object-fit:contain;
  flex:0 0 auto;
  align-self:center;
  filter:none;
}

.brand i{
  width:2.95rem;
  height:2.95rem;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:16px;
  background:var(--c-primary-soft);
  color:var(--c-primary);
}

.menu{
  display:grid;
  gap:.38rem;
  margin:0;
  width:100%;
  padding: 0rem 1rem;
  font-family: Nunito, DejaVu Sans, sans-serif;
  align-content:start;
  /*padding:.7rem .62rem .8rem;
  border:1px solid rgba(255,255,255,.16);
  border-radius:26px;
  background:linear-gradient(180deg, rgba(255,255,255,.18), rgba(255,255,255,.10));
  box-shadow:0 18px 34px rgba(15,23,42,.18);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);*/
}

.menu__group{
  display:grid;
  gap:0;
  padding:0;
  border-top:0px solid rgba(148,163,184,.14);
  align-content:start;
}

.menu__group:first-child{
  border-top:none;
  padding-top:0;
}

.menu__section{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:.85rem;
  width:100%;
  margin:0;
  padding:.32rem 1.25rem .4rem 1.55rem;
  border:1px solid transparent;
  border-radius:0;
  background:transparent;
  color:#68727d;
  font-size:.72rem;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:none;
  cursor:default;
  box-shadow:none;
  transition:color .18s ease;
}


.menu__section::after{
  content:'';
  position:absolute;
  left:1.55rem;
  right:1.25rem;
  bottom:0;
  height:1px;
  background:linear-gradient(90deg, rgba(148,163,184,.68) 0 34px, rgba(203,213,225,.78) 34px 100%);
}

.menu__section-label{
  display:inline-flex;
  align-items:center;
  gap:.55rem;
  flex:1 1 auto;
  font-family: 'Nunito', DejaVu Sans, sans-serif;
  font-size: inherit;
  font-weight: inherit;
}

.menu__section-caret{
  display:none;
}

.menu__section-caret i{
  display:block;
  line-height:1;
  transform:translateY(1px);
}

.menu__section:hover{
  color:#68727d;
  background:transparent;
  border-color:transparent;
  transform:none;
  box-shadow:none;
}

.menu__group.is-open .menu__section-caret{
  transform:none;
}

.menu__group.is-open .menu__section{
  color:#68727d;
  border-color:transparent;
  background:transparent;
  box-shadow:none;
  font-weight:700;
  font-size:.72rem;
}

.menu__group.is-open .menu__section-label{
  font-weight:700;
}

.menu__group-items{
  display:grid;
  gap:0;
  width:100%;
  margin-left:0;
  align-content:start;
  max-height:none;
  overflow:visible;
  padding:.22rem 0 .34rem;
  border-left:0;
  opacity:1;
  transform:none;
  pointer-events:auto;
  transition:none;
}

.menu__group.is-open .menu__group-items{
  max-height:none;
  padding:.22rem 0 .34rem;
  opacity:1;
  transform:none;
  pointer-events:auto;
}

.menu__item{
  position:relative;
  display:flex;
  align-items:center;
  width:100%;
  gap:.58rem;
  margin-bottom:0;
  padding:.5rem 1.35rem .5rem 1.75rem;
  border:1px solid transparent;
  border-radius:0;
  color:#4e5761;;
  font-size:.86rem;
  line-height:1.2;
  font-weight:600;
  overflow:hidden;
  background:transparent;
  box-shadow:none;
  border-top:Opx solid rgba(148,163,184,.14);
  transition:background-color .16s ease, color .16s ease;
}

/*.menu__item::before{
  content:'';
  position:absolute;
  left:0;
  right:0;
  top:auto;
  bottom:0;
  width:auto;
  height:2px;
  border-radius:0;
  background:linear-gradient(90deg, rgba(37,99,235,.95), rgba(14,165,233,.75));
  opacity:0;
  transform:scaleX(.2);
  transform-origin:left center;
  transition:opacity .16s ease, transform .16s ease;
}*/

.menu__item i{
  flex:0 0 auto;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:auto;
  height:auto;
  border-radius:0;
  background:transparent;
  border:0;
  color:#4e5761;
  box-shadow:none;
  font-size:.88rem;
}

.menu__item:hover{
  color:#1f4168;
  background:transparent;
  border-color:transparent;
  transform:none;
  box-shadow:none;
}

.menu__item:hover::before{
  opacity:.5;
  transform:scaleX(.55);
  background: transparent;
}

.menu__item:hover i{
  color:#1f4168;
}

.menu__item.is-active{
  color:#0056b2;
  border-color:transparent;
  box-shadow:none;
  background: transparent !important;
  font-weight: 800;
}

.menu__item.is-active::before{
  opacity:0;
  transform:scaleX(.2);
}

.menu__item.is-active i{
  color:#0056b2;
  box-shadow:none;
}

.menu__item.menu__sub{
  margin-left:0;
  width:100%;
  padding-left:2.45rem;
  padding-right:1.35rem;
  font-size:.86rem;
  opacity:.96;
}

.menu__item.menu__sub::after{
  content:'';
  position:absolute;
  left:0;
  top:50%;
  width:.55rem;
  height:1px;
  background:rgba(148,163,184,.34);
}

.topbar-btn{
  border-radius:14px;
}

.user-menu__trigger{
  display:inline-grid;
  grid-template-columns:1.85rem minmax(0,1fr) 1rem;
  align-items:center;
  column-gap:.7rem;
  height:42px;
  min-height:42px;
  min-width:170px;
  padding:0 .8rem;
  justify-content:flex-start;
  box-sizing:border-box;
  line-height:1;
  border-radius:14px !important;
}

.user-menu__trigger:hover{
  border-color:rgba(37,99,235,.18);
}

.user-menu__avatar{
  width:1.9rem;
  height:1.9rem;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:12px;
  background:var(--c-primary-soft);
  color:var(--c-primary);
}

.user-menu__avatar i{
  font-size:1rem;
}

.user-menu__identity{
  min-width:0;
  display:flex;
  align-items:center;
  text-align:left;
}

.user-menu__identity-name{
  display:block;
  margin:0;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.user-menu__identity-name{
  max-width:14ch;
  font-size:.8rem;
  font-weight:700;
  color:var(--c-text);
  line-height:1;
}

.user-menu__caret{
  width:1rem;
  height:1rem;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex:0 0 auto;
  color:#64748b;
  font-size:.68rem;
}

.user-menu:hover .user-menu__caret,
.user-menu__trigger:hover .user-menu__caret{
  color:#2563eb;
}

.user-menu__dropdown{
  border-color:rgba(148,163,184,.16);
  border-radius:18px;
  box-shadow:0 18px 40px rgba(15,23,42,.12);
  padding:.4rem 0;
}

.user-menu__header{
  border-bottom-color:rgba(148,163,184,.16);
}

.user-menu__item{
  margin:0 .35rem;
  border-radius:12px;
}

.user-menu__item:hover{
  background:rgba(248,250,252,.9);
}

.user-menu__item i{
  width:1.85rem;
  height:1.85rem;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:10px;
  background:rgba(248,250,252,.92);
  color:#475569;
}

.user-menu__item:hover i{
  background:rgba(37,99,235,.08);
  color:#2563eb;
}

.user-menu__item--danger:hover i{
  background:rgba(225,29,72,.08);
  color:#be123c;
}

@media (max-width:900px){
  .user-menu__trigger{
    min-width:150px;
  }

  .user-menu__identity-name{
    max-width:12ch;
  }
}

@media (max-width:640px){
  .user-menu__trigger{
    min-width:auto;
    height:42px;
    padding:0 .65rem;
  }

  .user-menu__avatar{
    width:1.8rem;
    height:1.8rem;
  }

  .user-menu__identity-name{
    max-width:11ch;
  }
}

.breadcrumbs a{
  background:rgba(248,250,252,.92);
}

.page-head{
  border-bottom:1px solid rgba(209,213,219,.9);
}

.page-head::after{
  height:1px;
  width:96px;
  background:linear-gradient(90deg,var(--c-primary),rgba(37,99,235,.2) 72%,transparent);
}

.card{
  border-color:rgba(148,163,184,.18);
  border-radius:var(--radius-lg);
  box-shadow:0 4px 18px rgba(15,23,42,.04);
}

.card__header{
  border-bottom-color:rgba(148,163,184,.16);
}

.card--soft,
.settings-card,
.settings-grid > .card,
.page-tree,
.upload-box{
  border-radius:var(--radius-xl);
}

.card--info{
  border-left:0;
  border-color:rgba(2,132,199,.16);
  background:linear-gradient(180deg,#fff,#f8fafc);
}

.btn{
  border-color:rgba(209,213,219,.9);
  box-shadow:0 1px 2px rgba(16,24,40,.04);
}

.btn--subtle{
  background:rgba(255,255,255,.92);
}

.btn--subtle:hover,
.btn--icon:hover{
  border-color:rgba(37,99,235,.18);
  background:rgba(37,99,235,.05);
}

.btn--primary{
  box-shadow:0 8px 18px rgba(37,99,235,.14);
}

.form__control,
.form__select,
.form__textarea,
.form-row input[type="text"],
.form-row input[type="email"],
.form-row input[type="number"],
.form-row input[type="password"],
.form-row select,
.form-row textarea{
  border-color:rgba(203,213,225,.9);
  transition:border-color .18s ease, box-shadow .18s ease, background-color .18s ease;
}

.form__control:hover,
.form__select:hover,
.form__textarea:hover,
.form-row input[type="text"]:hover,
.form-row input[type="email"]:hover,
.form-row input[type="number"]:hover,
.form-row input[type="password"]:hover,
.form-row select:hover,
.form-row textarea:hover{
  border-color:rgba(148,163,184,.9);
}

.pill,
.badge{
  border-color:rgba(148,163,184,.18);
  background:rgba(248,250,252,.92);
  color:var(--c-text);
  font-weight:700;
}

.pill--success,
.badge--success{
  background:rgba(34,197,94,.08);
  border-color:rgba(34,197,94,.16);
  color:#166534;
}

.pill--danger{
  background:rgba(225,29,72,.08);
  border-color:rgba(225,29,72,.16);
  color:#be123c;
}

.pill--warning,
.badge--warning{
  background:rgba(245,158,11,.10);
  border-color:rgba(245,158,11,.18);
  color:#b45309;
}

.badge--subtle,
.pill--draft{
  background:rgba(248,250,252,.92);
  border-color:rgba(148,163,184,.16);
  color:#475569;
}

.table-responsive{
  border-radius:var(--radius-lg);
}

.table{
  border-color:rgba(148,163,184,.16);
  border-radius:var(--radius-lg);
}

.table th{
  background:rgba(248,250,252,.9);
  color:#64748b;
}

.table th,
.table td{
  border-bottom-color:rgba(148,163,184,.14);
}

.table tbody tr:hover{
  background:rgba(248,250,252,.75);
}

.table--compact{
  table-layout:fixed;
  font-size:.8rem;
}

.table--compact th{
  font-size:.67rem;
  letter-spacing:.04em;
}

.table__meta{
  display:block;
  margin-top:.12rem;
  font-size:.72rem;
  color:var(--c-muted);
  line-height:1.3;
}

.table__strong{
  color:var(--c-text);
  font-weight:700;
  line-height:1.2;
}

.table__subtotal-row td{
  background:rgba(248,250,252,.9);
}

.table__total-row td{
  background:rgba(37,99,235,.05);
}

.empty{
  border-radius:var(--radius-lg);
  background:linear-gradient(180deg,#fff,#f8fafc);
}

.modal__dialog{
  border-color:rgba(148,163,184,.18);
  border-radius:var(--radius-xl);
  box-shadow:rgba(50,50,93,.25) 0 50px 100px -20px,rgba(0,0,0,.3) 0 30px 60px -30px,0 8px 24px rgba(15,23,42,.14);
}

.modal__dialog--workbench{
  width:min(1080px,96vw);
  max-height:90vh;
}

.modal__header,
.modal__footer{
  border-color:rgba(148,163,184,.16);
}

.modal__hero{
  padding:1.15rem 1.2rem;
  border-radius:22px;
  border:1px solid rgba(37,99,235,.16);
  background:radial-gradient(circle at top right, rgba(56,189,248,.18), transparent 32%), linear-gradient(180deg, rgba(37,99,235,.08), rgba(255,255,255,.98));
}

.info-card{
  display:flex;
  gap:.85rem;
  align-items:flex-start;
  padding:1rem 1.05rem;
  border-radius:18px;
  border:1px solid rgba(148,163,184,.2);
  background:rgba(255,255,255,.88);
  box-shadow:var(--shadow-3);
}

.icon-tile{
  width:2.65rem;
  height:2.65rem;
  flex:0 0 auto;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:14px;
  background:var(--c-primary-soft);
  color:var(--c-primary);
}

.drag-handle,
.ucto-drag-handle{
  cursor:grab;
  min-width:2.4rem;
  min-height:2.4rem;
  padding:.55rem;
  border-radius:12px;
  color:var(--c-muted);
}

.drag-handle:hover,
.ucto-drag-handle:hover{
  background:rgba(37,99,235,.08);
  color:#2563eb;
}

.drag-handle:active,
.ucto-drag-handle:active{
  cursor:grabbing;
}

.is-dragging{
  opacity:.55;
}

.is-drop-target{
  border-color:rgba(59,130,246,.5) !important;
  box-shadow:inset 0 0 0 2px rgba(37,99,235,.18);
}

.upload-box{
  border-radius:var(--radius-xl);
  background:linear-gradient(180deg,#fff,#f8fafc);
}

.upload-box:hover,
.upload-box.drag-over{
  border-color:rgba(37,99,235,.26);
  background:rgba(37,99,235,.05);
}

@media (max-width:1024px){
  .brand{
    padding:.15rem 1rem .8rem;
    margin:0 0 .45rem;
  }

  .brand > .brand__logo,
  .brand img.brand__logo{
    height:58px !important;
    max-height:58px !important;
    max-width:220px !important;
  }

  .menu{
    margin:0;
    width:100%;
    padding:0;
  }

  .menu__section{
    padding:.82rem 1rem .82rem 1.2rem;
    font-size:.78rem;
    border-radius:0;
  }

  .menu__item{
    padding:.84rem 1rem .84rem 1.35rem;
    border-radius:0;
  }

  .card,
  .table,
  .table-responsive{
    padding:.1rem .9rem .75rem;
  }
  .modal__dialog,
  .upload-box{
    border-radius:var(--radius-lg);
  }
}

@media (max-width:640px){
  .brand{
    padding:.1rem 0 .75rem;
    margin:0 0 .4rem;
  }

  .brand > .brand__logo,
  .brand img.brand__logo{
    height:50px !important;
    max-height:50px !important;
    max-width:190px !important;
  }

  .menu{
    margin:0;
    width:100%;
    padding:0;
  }

  .menu__section{
    padding:.76rem .9rem .76rem 1.05rem;
    font-size:.74rem;
    border-radius:0;
  }

  .menu__item{
    gap:.56rem;
    padding:.8rem .9rem .8rem 1.15rem;
    border-radius:0;
    font-size:.82rem;
  }

  .menu__item i{
    width:auto;
    height:auto;
    border-radius:0;
  }
}

.notifications-shell{position:relative}
.notifications-trigger{position:relative;display:inline-flex;align-items:center;justify-content:center;width:42px;min-width:42px;height:42px;padding:0;border-radius:14px}
.notifications-trigger:hover{border-color:rgba(37,99,235,.18)}
.notifications-trigger[aria-expanded="true"]{background:rgba(239,246,255,.92);border-color:rgba(59,130,246,.22);color:#1d4ed8}
.notifications-trigger__badge{position:absolute;top:-6px;right:-6px;display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 .35rem;border-radius:999px;background:#dc2626;color:#fff;font-size:12px;font-weight:800;box-shadow:0 8px 20px rgba(220,38,38,.24)}
.notifications-trigger__badge.is-empty{display:none}
.notifications-drawer{position:fixed;inset:0;z-index:1500;opacity:0;pointer-events:none;transition:opacity .24s ease}
.notifications-drawer[hidden]{display:none !important}
.notifications-drawer.is-open{opacity:1;pointer-events:auto}
.notifications-drawer__backdrop{position:absolute;inset:0;background:rgba(15,23,42,.34);backdrop-filter:blur(4px);opacity:0;transition:opacity .24s ease}
.notifications-drawer__panel{position:absolute;top:0;right:0;height:100%;width:min(460px,100%);max-width:100%;display:flex;flex-direction:column;background:linear-gradient(180deg,#ffffff,#f8fafc);border-left:1px solid rgba(148,163,184,.28);box-shadow:-24px 0 60px rgba(15,23,42,.18);transform:translateX(100%);transition:transform .24s ease}
.notifications-drawer.is-open .notifications-drawer__backdrop{opacity:1}
.notifications-drawer.is-open .notifications-drawer__panel{transform:translateX(0)}
.notifications-drawer__header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:1rem 1rem .85rem;border-bottom:1px solid var(--c-border)}
.notifications-drawer__eyebrow{display:inline-flex;align-items:center;gap:.45rem;padding:.3rem .65rem;border-radius:999px;background:#eff6ff;border:1px solid #bfdbfe;color:#1d4ed8;font-size:var(--fs-300);font-weight:800;text-transform:uppercase;letter-spacing:.08em}
.notifications-drawer__title{margin:.65rem 0 0;font-size:1.35rem;line-height:1.05;letter-spacing:-.04em}
.notifications-drawer__body{flex:1;overflow-y:auto;padding:.8rem}
.notifications-drawer__footer{display:flex;justify-content:space-between;align-items:center;gap:.75rem;flex-wrap:nowrap;padding:.85rem 1rem;border-top:1px solid var(--c-border);background:rgba(255,255,255,.92)}
.notifications-drawer__footer .btn[aria-disabled="true"],.notifications-drawer__footer .btn:disabled{opacity:.55;cursor:not-allowed}
.notifications-empty{display:grid;place-items:center;gap:.45rem;min-height:220px;padding:1.4rem;border:1px dashed var(--c-border);border-radius:18px;background:#fff;text-align:center;color:var(--c-muted)}
.notifications-empty i{font-size:2.6rem;opacity:.35}
.notifications-empty p{margin:0;max-width:28ch}
.notifications-list{display:grid;gap:.65rem}
.notification-item{position:relative;display:grid;gap:.65rem;padding:1.1rem 1.15rem 1rem;border:1px solid rgba(203,213,225,.85);border-radius:18px;background:rgba(255,255,255,.96);box-shadow:0 10px 28px rgba(15,23,42,.06)}
.notification-item--important{border-color:#fda4af}
.notification-item--normal{border-color:#fdba74}
.notification-item--info{border-color:#93c5fd}
.notification-item.is-reminder{padding:1.25rem 1.3rem 1.15rem;border-color:#fbbf24;box-shadow:0 12px 24px rgba(245,158,11,.14);background:linear-gradient(180deg,#fffdf7 0%,#fff8e8 100%)}
.notification-item.is-read{opacity:.76}
.notification-item__dismiss{position:absolute;top:.55rem;right:.55rem;display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border:none;border-radius:10px;background:transparent;color:#94a3b8;cursor:pointer;transition:background .18s ease,color .18s ease}
.notification-item__dismiss:hover{background:#f1f5f9;color:#dc2626}
.notification-item__meta{display:flex;justify-content:flex-start;gap:.5rem;align-items:center;padding-right:2rem}
.notification-item__meta-right{display:flex;align-items:center;justify-content:flex-start;gap:.45rem;flex-wrap:wrap;font-size:.72rem;color:var(--c-muted);text-align:left}
.notification-item__date{font-variant-numeric:tabular-nums}
.notification-item__level{display:inline-flex;align-items:center;gap:.35rem;padding:.22rem .55rem;border-radius:999px;border:1px solid;font-size:.67rem;font-weight:800;letter-spacing:.01em}
.notification-item__level--important{background:#fff1f2;border-color:#fecdd3;color:#be123c}
.notification-item__level--normal{background:#fff7ed;border-color:#fed7aa;color:#9a3412}
.notification-item__level--info{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}
.notification-item__title{margin:0;font-size:1.08rem;line-height:1.25;padding-right:2.2rem;padding-top:.1rem}
.notification-item__message{display:grid;gap:.35rem}
.notification-item__text{color:#334155;font-size:.84rem;line-height:1.55}
.notification-item__text--full{padding-top:.15rem}
.notification-item__expand{justify-self:flex-start;border:none;background:transparent;padding:0;color:#2563eb;font:inherit;font-size:.78rem;font-weight:700;cursor:pointer}
.notification-item__actions{display:flex;justify-content:space-between;align-items:flex-end;gap:.55rem;min-height:30px}
.notification-item__link{display:inline-flex;align-items:center;gap:.38rem;color:#0f62fe;font-size:.78rem;font-weight:700;text-decoration:none}
.notification-item__link:hover{text-decoration:underline;color:#1d4ed8}
.notification-item__reminder{display:inline-flex;align-items:center;justify-content:center;align-self:flex-end;width:30px;height:30px;margin-left:auto;border:none;border-radius:10px;background:#eff6ff;color:#2563eb;cursor:pointer;transition:background .18s ease,color .18s ease}
.notification-item__reminder i{font-size:14px;line-height:1}
.notification-item__reminder:hover{background:#dbeafe;color:#1d4ed8}
.notification-item.is-reminder .notification-item__reminder{background:#fef3c7;color:#d97706;box-shadow:none}
.notification-item.is-reminder .notification-item__reminder i{color:#d97706;font-size:15px}
.notification-item.is-reminder .notification-item__reminder:hover{background:#fde68a;color:#b45309}

@media (max-width:1024px){
  .notifications-trigger{width:44px;min-width:44px;height:44px}
  .notifications-trigger__badge{position:absolute;top:-4px;right:-4px;min-width:20px;height:20px;padding:0 .35rem}
}

@media (max-width:640px){
  .notifications-drawer__panel{width:100%;max-width:100%}
  .notifications-drawer__body{padding:.65rem}
  .notification-item{padding:1rem .95rem .9rem;border-radius:16px}
  .notification-item.is-reminder{padding:1.1rem 1.05rem .98rem}
  .notifications-drawer__footer{padding:.75rem}
  .notifications-drawer__footer .btn:last-child{flex:1}
}
