:root{
  --bg: #ffffff;
  --panel: #ffffff;
  --muted: #5b6473;
  --text: #0b1220;
  --border: rgba(15,23,42,.10);
  --shadow: 0 12px 32px rgba(15,23,42,.08);
  --primary: #2563eb;
  --primary-2: #38bdf8;
  --focus: rgba(37,99,235,.20);
  --pill: rgba(2,132,199,.10);
  --ok: rgba(16,185,129,.14);
  --warn: rgba(245,158,11,.16);
  --danger: rgba(239,68,68,.14);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color:var(--text);
  background: #F5F7FA;
}

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

.app{min-height:100%;display:flex;flex-direction:column}

.topbar{
  position:sticky;top:0;z-index:10;
  backdrop-filter:saturate(140%) blur(12px);
  background: rgba(255,255,255,.78);
  border-bottom:1px solid var(--border);
}
.topbar__inner{
  max-width:1100px;
  margin:0 auto;
  padding:12px 16px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}

.brand{display:flex;align-items:center;gap:10px}
.brand__mark{
  width:14px;height:14px;border-radius:8px;
  background: linear-gradient(135deg, var(--primary), var(--primary-2));
  box-shadow: 0 8px 18px rgba(37,99,235,.24);
}
.brand__text{font-weight:650;letter-spacing:-.2px}

.topbar__actions{display:flex;align-items:center;gap:10px}
.userchip{
  display:none;
  align-items:center;
  gap:8px;
  padding:8px 10px;
  border:1px solid var(--border);
  border-radius:8px;
  background: rgba(255,255,255,.7);
}
.userchip__dot{
  width:8px;height:8px;border-radius:999px;
  background: rgba(16,185,129,.85);
  box-shadow: 0 0 0 4px rgba(16,185,129,.12);
}
.userchip__text{font-size:13px;color:var(--muted)}

.main{
  flex:1;
  padding:22px 16px 34px;
  width:100%;
}
.container{
  width:100%;
  max-width:1100px;
  margin:0 auto;
}
.main--center .container{
  display:flex;
  align-items:flex-start;
  justify-content:center;
}

.card{
  width:100%;
  max-width:440px;
  background: rgba(255,255,255,.86);
  border:1px solid var(--border);
  border-radius:8px;
  box-shadow: var(--shadow);
  padding:18px;
}
.card__head{margin-bottom:14px}
.h1{
  margin:0;
  font-size:22px;
  letter-spacing:-.4px;
}
.sub{
  margin:8px 0 0;
  color:var(--muted);
  font-size:14px;
  line-height:1.4;
}
.h2{
  margin:0;
  font-size:16px;
  letter-spacing:-.3px;
}

.form{display:flex;flex-direction:column;gap:12px}
.field{display:flex;flex-direction:column;gap:7px}
.field__label{font-size:13px;color:#273042;font-weight:600}
.field__hint{font-size:12px;color:var(--muted)}
.input{
  height:44px;
  padding:0 12px;
  border:1px solid rgba(15,23,42,.14);
  border-radius:8px;
  background: rgba(255,255,255,.92);
  outline:none;
  transition: box-shadow .15s ease, border-color .15s ease, transform .15s ease;
}
.input:focus{
  border-color: rgba(37,99,235,.40);
  box-shadow: 0 0 0 6px var(--focus);
}
.input:disabled{opacity:.6}

.textarea{
  width:100%;
  padding:10px 12px;
  border:1px solid rgba(15,23,42,.14);
  border-radius:8px;
  background: rgba(255,255,255,.92);
  outline:none;
  resize:vertical;
  min-height:96px;
  font-family: inherit;
  font-size:14px;
  line-height:1.35;
  transition: box-shadow .15s ease, border-color .15s ease;
}
.textarea:focus{
  border-color: rgba(37,99,235,.40);
  box-shadow: 0 0 0 6px var(--focus);
}

.segmented{
  display:inline-flex;
  padding:4px;
  border-radius:8px;
  background: rgba(15,23,42,.04);
  border:1px solid rgba(15,23,42,.10);
  gap:4px;
}
.segmented__input{position:absolute;opacity:0;pointer-events:none}
.segmented__btn{
  height:36px;
  padding:0 12px;
  border-radius:8px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:700;
  font-size:13px;
  color:#233046;
  cursor:pointer;
  user-select:none;
  border:1px solid transparent;
}
.segmented__input:checked + .segmented__btn{
  background: rgba(255,255,255,.9);
  border-color: rgba(15,23,42,.10);
  box-shadow: 0 10px 20px rgba(15,23,42,.08);
}

.select2{position:relative}
.select2__menu{
  position:absolute;
  left:0;right:0;
  top:calc(100% + 6px);
  border-radius:8px;
  border:1px solid rgba(15,23,42,.12);
  background: rgba(255,255,255,.96);
  box-shadow: 0 18px 44px rgba(15,23,42,.14);
  padding:6px;
  max-height:220px;
  overflow:auto;
  z-index:60;
}
.select2__item{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:10px 10px;
  border-radius:8px;
  cursor:pointer;
}
.select2__item:hover{background: rgba(2,132,199,.08)}
.select2__name{font-weight:650;font-size:13px;color:#233046}
.select2__meta{font-size:12px;color:var(--muted)}

.finance{width:100%}
.finance__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:14px;
}
.finance__actions{
  display:flex;
  align-items:center;
  gap:10px;
}
.finTabs{
  margin-top:10px;
  display:inline-flex;
  align-items:center;
  gap:0;
  padding:4px;
  border:1px solid var(--border);
  background: rgba(255,255,255,.75);
  border-radius:999px;
  box-shadow: 0 10px 24px rgba(15,23,42,.04);
}
.finTabs__btn{
  appearance:none;
  border:0;
  background:transparent;
  color:#233046;
  font-weight:750;
  font-size:13px;
  padding:8px 12px;
  border-radius:999px;
  cursor:pointer;
}
.finTabs__btn:hover{background: rgba(2,132,199,.06)}
.finTabs__btn.is-active{
  background: rgba(2,132,199,.10);
  box-shadow: inset 0 0 0 1px rgba(2,132,199,.16);
}
.tablewrap{width:100%;overflow:auto;border-radius:12px;border:1px solid var(--border)}
.table{
  width:100%;
  border-collapse:collapse;
  min-width: 900px;
  background: rgba(255,255,255,.82);
}
.table th,.table td{
  padding:10px 12px;
  border-bottom:1px solid var(--border);
  font-size:13px;
  color:#233046;
  text-align:left;
  vertical-align:top;
}
.table thead th{
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--muted);
  background: rgba(248,250,252,.8);
}
.table .right{text-align:right}
.table td.amount--income,
.table td.amount--expense{
  font-weight:900;
  letter-spacing:-.3px;
  white-space:nowrap;
}
.table td.amount--income{color:#0a2c22}
.table td.amount--expense{color:#4c1212}
.pager{
  margin-top:12px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.only-mobile{display:inline-flex}
.finance__grid{
  display:grid;
  grid-template-columns: 1fr;
  gap:14px;
}
.finance__add{display:none}
.card--wide{max-width:none}
.finlist{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.fincard{
  border:1px solid var(--border);
  background: rgba(255,255,255,.82);
  border-radius:8px;
  box-shadow: 0 10px 24px rgba(15,23,42,.06);
  padding:14px;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.fincard__title{letter-spacing:-.2px}
.fincard__sub{margin-top:6px;color:var(--muted);font-size:13px;font-style:italic;line-height:1.35}
.fincard__meta{margin-top:10px;display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.pill--income{background: rgba(16,185,129,.12); border-color: rgba(16,185,129,.20); color:#0a2c22}
.pill--expense{background: rgba(239,68,68,.10); border-color: rgba(239,68,68,.18); color:#4c1212}
.amount{
  font-weight:900;
  letter-spacing:-.3px;
  font-size:16px;
  white-space:nowrap;
}
.amount--income{color:#0a2c22}
.amount--expense{color:#4c1212}
.fincard__actions{display:flex;gap:10px;align-items:center}
.goals__head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.goalcard{
  border:1px solid var(--border);
  background: rgba(255,255,255,.82);
  border-radius:8px;
  box-shadow: 0 10px 24px rgba(15,23,42,.06);
  padding:14px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.goalcard__head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.goalcard__title{font-weight:850;letter-spacing:-.2px;min-width:0}
.goalcard__pct{font-weight:900;letter-spacing:-.3px;white-space:nowrap}
.goalcard__meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.goalbar{
  width:100%;
  height:12px;
  border-radius:999px;
  border:1px solid rgba(15,23,42,.10);
  background: rgba(15,23,42,.05);
  overflow:hidden;
}
.goalbar__fill{
  height:100%;
  width:0%;
  border-radius:999px;
  background: linear-gradient(90deg, rgba(37,99,235,.85), rgba(56,189,248,.85));
}
.goalcard__amounts{color:var(--muted);font-size:13px}

@media (min-width: 980px){
  .only-mobile{display:none}
  .finance__add{display:block}
  .finance__grid{grid-template-columns: 1fr 420px}
}

.vehicles{width:100%}
.vehicles__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:14px;
}
.vehicles__actions{
  display:flex;
  align-items:center;
  gap:10px;
}
.vehlist{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.vehcard{
  border:1px solid var(--border);
  background: rgba(255,255,255,.82);
  border-radius:16px;
  box-shadow: 0 10px 24px rgba(15,23,42,.06);
  padding:14px;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.vehcard__title{font-weight:850;letter-spacing:-.2px}
.vehcard__sub{margin-top:6px;color:var(--muted);font-size:13px;line-height:1.35}
.vehcard__meta{margin-top:10px;display:flex;gap:8px;align-items:center;flex-wrap:wrap}

.tasks{width:100%}
.tasks__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:14px;
}
.tasks__actions{
  display:flex;
  align-items:center;
  gap:10px;
}
.task-step-row{
  display:flex;
  align-items:center;
  gap:8px;
  padding:6px 0;
}
.task-step-row .check{margin:0}
.task-step-row .step-text{flex:1;font-size:13px;color:var(--text)}
.task-step-row .step-text.is-completed{
  text-decoration:line-through;
  color:var(--muted);
}
.task-step-row .btn--remove-step{
  width:28px;height:28px;
  border-radius:6px;
  border:1px solid rgba(239,68,68,.18);
  background:rgba(239,68,68,.06);
  color:#7a1c1c;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:16px;
  line-height:1;
}
.task-step-row .btn--remove-step:hover{
  border-color:rgba(239,68,68,.30);
  background:rgba(239,68,68,.12);
}
.btn--add-step{
  margin-top:6px;
  font-size:13px;
  padding:6px 12px;
}
.task-deadline-badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:4px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:700;
}
.task-deadline-badge.is-overdue{
  background:rgba(239,68,68,.10);
  border-color:rgba(239,68,68,.18);
  color:#4c1212;
}
.task-deadline-badge.is-upcoming{
  background:rgba(245,158,11,.10);
  border-color:rgba(245,158,11,.16);
  color:#5a3a12;
}
.task-deadline-badge.is-ok{
  background:rgba(16,185,129,.10);
  border-color:rgba(16,185,129,.16);
  color:#0a2c22;
}

.col--check{
  width:44px;
  text-align:center;
  vertical-align:middle;
}

.task-check{
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  margin:0;
}

.row--completed{
  opacity:.55;
}

.row--completed td:not(.col--check){
  text-decoration:line-through;
  color:var(--muted);
}

.tasks__footer{
  margin-top:14px;
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}

.check{
  display:flex;
  align-items:center;
  gap:10px;
  user-select:none;
  margin-top:2px;
}
.check__input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}
.check__box{
  width:18px;height:18px;
  border-radius:8px;
  border:1px solid rgba(15,23,42,.18);
  background: rgba(255,255,255,.9);
  box-shadow: 0 1px 0 rgba(15,23,42,.04);
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.check__box::after{
  content:"";
  width:10px;height:10px;
  border-radius:8px;
  background: linear-gradient(135deg, var(--primary), var(--primary-2));
  opacity:0;
  transform:scale(.85);
  transition:opacity .12s ease, transform .12s ease;
}
.check__input:checked + .check__box::after{
  opacity:1;
  transform:scale(1);
}
.check__text{font-size:14px;color:var(--muted)}
.switch{
  display:flex;
  align-items:center;
  gap:10px;
  user-select:none;
  cursor:pointer;
}
.switch__input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}
.switch__track{
  width:42px;
  height:24px;
  border-radius:999px;
  border:1px solid rgba(15,23,42,.16);
  background: rgba(15,23,42,.06);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.6);
  position:relative;
  flex:0 0 auto;
  transition: background-color .12s ease, border-color .12s ease;
}
.switch__track::after{
  content:"";
  width:18px;
  height:18px;
  border-radius:999px;
  background: rgba(255,255,255,.95);
  border:1px solid rgba(15,23,42,.12);
  box-shadow: 0 8px 16px rgba(15,23,42,.10);
  position:absolute;
  top:50%;
  left:3px;
  transform: translateY(-50%);
  transition: left .12s ease;
}
.switch__input:checked + .switch__track{
  background: rgba(37,99,235,.18);
  border-color: rgba(37,99,235,.26);
}
.switch__input:checked + .switch__track::after{left:21px}
.switch__text{font-size:14px;color:var(--muted);font-weight:600}

.actions{display:flex;gap:10px;margin-top:4px}
.btn{
  appearance:none;
  border:1px solid transparent;
  border-radius:8px;
  padding:8px 12px;
  font-weight:650;
  letter-spacing:-.2px;
  cursor:pointer;
  transition: transform .12s ease, box-shadow .12s ease, background-color .12s ease, border-color .12s ease;
}
.btn:active{transform: translateY(1px)}
.btn:disabled{opacity:.55;cursor:not-allowed}
.btn--primary{
  width:100%;
  background: linear-gradient(135deg, var(--primary), var(--primary-2));
  color:white;
  box-shadow: 0 10px 26px rgba(37,99,235,.22);
}
.btn--inline{width:auto}
.btn--primary:hover{box-shadow: 0 14px 34px rgba(37,99,235,.26)}
.btn--ghost{
  background: rgba(255,255,255,.7);
  border-color: rgba(15,23,42,.10);
  color: #233046;
}
.btn--ghost:hover{border-color: rgba(15,23,42,.16)}
.btn--danger{
  background: rgba(239,68,68,.10);
  border-color: rgba(239,68,68,.18);
  color:#7a1c1c;
}
.btn--danger:hover{border-color: rgba(239,68,68,.26)}

.alert{
  margin-top:2px;
  border-radius:8px;
  padding:10px 12px;
  font-size:13px;
  border:1px solid rgba(15,23,42,.10);
  background: rgba(2,132,199,.08);
  color:#12335a;
}
.alert--danger{background: var(--danger); color:#4c1212}
.alert--ok{background: var(--ok); color:#0a2c22}

.home{width:100%}
.home__head{margin:6px 0 14px}

.grid{
  display:grid;
  grid-template-columns: 1fr;
  gap:12px;
}
.tile--link{color:inherit}
.tile{
  display:flex;
  gap:12px;
  align-items:center;
  padding:14px;
  border-radius:8px;
  border:1px solid var(--border);
  background: rgba(255,255,255,.82);
  box-shadow: 0 10px 24px rgba(15,23,42,.06);
  cursor:default;
  outline:none;
}
.tile--link{cursor:pointer}
.tile:focus{
  box-shadow: 0 0 0 6px rgba(56,189,248,.22), 0 10px 24px rgba(15,23,42,.06);
}
.tile__icon{
  width:38px;height:38px;border-radius:8px;
  background: linear-gradient(135deg, rgba(37,99,235,.14), rgba(56,189,248,.14));
  border:1px solid rgba(37,99,235,.12);
  display:flex;
  align-items:center;
  justify-content:center;
  color: rgba(37,99,235,.95);
}
.tile__icon svg{
  width:20px;
  height:20px;
  display:block;
}
.tile__body{min-width:0}
.tile__title{font-weight:700;letter-spacing:-.2px}
.tile__desc{
  margin-top:6px;
  color: var(--muted);
  font-size:13px;
  line-height:1.35;
}
.tile__meta{margin-top:6px}
.pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:12px;
  color: #0f3b55;
  background: var(--pill);
  border: 1px solid rgba(2,132,199,.14);
  padding:5px 9px;
  border-radius:999px;
}

.pill.pill--income{background: rgba(16,185,129,.12); border-color: rgba(16,185,129,.20); color:#0a2c22}
.pill.pill--expense{background: rgba(239,68,68,.10); border-color: rgba(239,68,68,.18); color:#4c1212}

@media (min-width: 720px){
  .main{padding:30px 18px 44px}
  .userchip{display:inline-flex}
  .grid{grid-template-columns: repeat(2, minmax(0, 1fr))}
  .tile{padding:16px}
}

@media (min-width: 980px){
  .grid{grid-template-columns: repeat(3, minmax(0, 1fr))}
}

.notes{
  width:100%;
}
.notes__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:14px;
}
.notes__toolbar{
  display:flex;
  gap:10px;
  align-items:center;
  margin:12px 0 14px;
  flex-wrap:wrap;
}
.search{
  position:relative;
  flex:1;
  min-width:220px;
}
.search__icon{
  position:absolute;
  left:12px;
  top:50%;
  transform: translateY(-50%);
  width:18px;height:18px;
  color: rgba(2,132,199,.85);
}
.input--search{
  padding-left:40px;
}
.notes__list{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.noteitem{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  padding:14px;
  border-radius:8px;
  border:1px solid var(--border);
  background: rgba(255,255,255,.82);
  box-shadow: 0 10px 24px rgba(15,23,42,.06);
  cursor:pointer;
  min-width:0;
}
.noteitem__title{
  font-weight:750;
  letter-spacing:-.2px;
}
.noteitem__desc{
  margin-top:6px;
  color: var(--muted);
  font-size:13px;
  line-height:1.35;
  overflow:hidden;
  text-overflow:ellipsis;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
}
.noteitem__meta{
  display:flex;
  align-items:center;
  gap:8px;
  margin-top:10px;
}
.badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:5px 9px;
  border-radius:999px;
  font-size:12px;
  border:1px solid rgba(15,23,42,.10);
  background: rgba(15,23,42,.04);
  color:#233046;
}
.badge--lock{
  background: rgba(245,158,11,.12);
  border-color: rgba(245,158,11,.18);
  color:#5a3a12;
}
.badge svg{width:14px;height:14px;display:block}

.modal[hidden]{display:none}
.modal{
  position:fixed;
  inset:0;
  z-index:50;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  padding:16px;
}
.modal__overlay{
  position:absolute;
  inset:0;
  background: rgba(2,6,23,.42);
}
.modal__panel{
  position:relative;
  width:100%;
  max-width:560px;
  border-radius:8px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.92);
  box-shadow: 0 18px 50px rgba(2,6,23,.22);
  padding:16px;
  max-height: calc(100dvh - 32px);
  overflow:hidden;
  display:flex;
  flex-direction:column;
}
.page--quick_notes #modalCreate .modal__panel{
  max-width:640px;
}
.page--quick_notes #modalView .modal__panel{
  max-width:980px;
}
.modal__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:12px;
}
.modal__actions{
  display:flex;
  align-items:center;
  gap:10px;
}
.modal__body{
  flex: 1 1 auto;
  overflow:auto;
  padding-right:4px;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
}
.modal__title{font-weight:800;letter-spacing:-.3px;font-size:18px}
.modal__sub{margin-top:6px;color:var(--muted);font-size:13px;line-height:1.35}
.iconbtn{
  width:40px;
  height:40px;
  border-radius:8px;
  border:1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.7);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
}
.iconbtn:disabled{
  opacity:.5;
  cursor:not-allowed;
}
.iconbtn--danger{
  background: rgba(239,68,68,.10);
  border-color: rgba(239,68,68,.18);
  color:#7a1c1c;
}
.iconbtn--danger:hover{border-color: rgba(239,68,68,.26)}
.iconbtn svg{width:18px;height:18px;display:block}

.actions--row{justify-content:flex-end}
.actions--row .btn{height:42px}

.view{
  padding:10px 0 2px;
}
.view__title{
  font-weight:850;
  letter-spacing:-.3px;
  font-size:18px;
}
.view__desc{
  margin-top:10px;
  color: var(--muted);
  line-height:1.5;
  font-size:14px;
  white-space:pre-wrap;
}

.social-media{width:100%}
.social-media__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:14px;
}
.social-media__layout{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
}
.social-media__editor{min-width:0}
.social-media__preview{min-width:0}

.sm-canvas-wrap{
  display:flex;
  justify-content:center;
  align-items:flex-start;
  padding:10px 0;
}

.sm-tabs{
  display:inline-flex;
  align-items:center;
  gap:0;
  padding:4px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.75);
  border-radius:999px;
  box-shadow:0 10px 24px rgba(15,23,42,.04);
  margin-bottom:10px;
}
.sm-tabs__btn{
  appearance:none;
  border:0;
  background:transparent;
  color:#233046;
  font-weight:750;
  font-size:12px;
  padding:6px 10px;
  border-radius:999px;
  cursor:pointer;
}
.sm-tabs__btn:hover{background:rgba(2,132,199,.06)}
.sm-tabs__btn.is-active{
  background:rgba(2,132,199,.10);
  box-shadow:inset 0 0 0 1px rgba(2,132,199,.16);
}

.sm-bg-panel{margin-top:8px}

.sm-file-label{display:block;cursor:pointer}
.sm-file-input{position:absolute;opacity:0;pointer-events:none}
.sm-file-name{
  margin-top:6px;
  font-size:12px;
  color:var(--muted);
  font-style:italic;
}

.sm-drop-zone{
  border:2px dashed var(--border);
  border-radius:8px;
  padding:20px;
  text-align:center;
  cursor:pointer;
  transition:border-color .15s ease, background-color .15s ease;
  position:relative;
  background:rgba(255,255,255,.5);
}
.sm-drop-zone:hover{
  border-color:var(--primary);
  background:rgba(37,99,235,.04);
}
.sm-drop-zone.is-dragover{
  border-color:var(--primary);
  background:rgba(37,99,235,.08);
  box-shadow:0 0 0 3px var(--focus);
}
.sm-drop-zone__content{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:4px;
  pointer-events:none;
}

.sm-presets{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(80px,1fr));
  gap:8px;
}
.sm-presets--sm{
  grid-template-columns:repeat(auto-fill,36px);
  gap:6px;
}
.sm-preset{
  width:100%;
  aspect-ratio:1;
  border-radius:8px;
  border:2px solid transparent;
  cursor:pointer;
  transition:border-color .15s ease;
}
.sm-preset:hover{border-color:var(--primary)}
.sm-preset.is-active{border-color:var(--primary);box-shadow:0 0 0 3px var(--focus)}

#smCanvas{
  border:1px solid var(--border);
  border-radius:8px;
  box-shadow:0 12px 32px rgba(15,23,42,.08);
  cursor:default;
  max-width:100%;
  height:auto;
}

.sm-download{
  margin-top:12px;
  display:flex;
  justify-content:center;
}

@media (min-width: 980px){
  .social-media__layout{
    grid-template-columns:380px 1fr;
    align-items:start;
  }
  .social-media__editor{
    position:sticky;
    top:70px;
    max-height:calc(100vh - 80px);
  }
}

@media (min-width: 720px){
  .modal{align-items:center}
  .modal__panel{padding:18px}
}

.ia-media{width:100%}
.ia-media__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:14px;
}
.ia-media__layout{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
}
.ia-media__editor{min-width:0}
.ia-media__preview{min-width:0}

.ia-colors{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.ia-color-item{
  width:60px;
  position:relative;
}
.ia-color-item .btn--remove-color{
  position:absolute;
  top:-6px;
  right:-6px;
  width:20px;
  height:20px;
  border-radius:50%;
  border:1px solid rgba(239,68,68,.18);
  background:rgba(239,68,68,.06);
  color:#7a1c1c;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:12px;
  line-height:1;
  padding:0;
}
.ia-color-item .btn--remove-color:hover{
  border-color:rgba(239,68,68,.30);
  background:rgba(239,68,68,.12);
}

.ia-preview-wrap{
  min-height:300px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:20px;
  border:1px solid var(--border);
  border-radius:8px;
  background:rgba(248,250,252,.5);
}
.ia-placeholder{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
}
.ia-preview-wrap img{
  max-width:100%;
  height:auto;
  border-radius:4px;
  box-shadow:0 4px 12px rgba(0,0,0,.08);
}

.ia-actions{
  display:flex;
  gap:10px;
  margin-top:16px;
  flex-wrap:wrap;
}

.ia-status{
  margin-top:12px;
  padding:10px 14px;
  border-radius:8px;
  font-size:13px;
  line-height:1.4;
}
.ia-status.is-loading{
  background:rgba(37,99,235,.08);
  border:1px solid rgba(37,99,235,.16);
  color:#1e40af;
}
.ia-status.is-error{
  background:rgba(239,68,68,.08);
  border:1px solid rgba(239,68,68,.16);
  color:#991b1b;
}
.ia-status.is-success{
  background:rgba(16,185,129,.08);
  border:1px solid rgba(16,185,129,.16);
  color:#065f46;
}

@media (min-width: 980px){
  .ia-media__layout{
    grid-template-columns:380px 1fr;
    align-items:start;
  }
}

.settings{width:100%}
.settings__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:14px;
}
.settings__tabs{
  display:flex;
  gap:4px;
  padding:4px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.75);
  border-radius:999px;
  box-shadow:0 10px 24px rgba(15,23,42,.04);
  margin-bottom:16px;
  overflow-x:auto;
}
.settings__tab{
  appearance:none;
  border:0;
  background:transparent;
  color:#233046;
  font-weight:750;
  font-size:13px;
  padding:8px 16px;
  border-radius:999px;
  cursor:pointer;
  white-space:nowrap;
}
.settings__tab:hover{background:rgba(2,132,199,.06)}
.settings__tab.is-active{
  background:rgba(2,132,199,.10);
  box-shadow:inset 0 0 0 1px rgba(2,132,199,.16);
}
.settings__content{
  width:100%;
}
.settings__panel{
  width:100%;
}
.settings__placeholder{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  padding:40px 20px;
  text-align:center;
}
