
@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=JetBrains+Mono:wght@400;500;600&display=swap');
:root{
  /* MERKID.IS — Warm professional */
  --bg:#e6e1d8;--s1:#f0ece4;--s2:#e6e0d6;--s3:#d9d3c8;--s4:#d0c9be;
  --border:#bfb9af;--border2:#afa8a0;
  --acc:#2a5e1e;--acc-dim:rgba(42,94,30,0.12);--acc-glow:rgba(42,94,30,0.22);
  --acc-light:#357a26;--acc-bright:#2a5e1e;
  --blue:#1a6fba;--blue-dim:rgba(26,111,186,0.1);
  --cold:#0a8fa8;--cold-dim:rgba(10,143,168,0.1);
  --frozen:#6040b0;--frozen-dim:rgba(96,64,176,0.1);
  --red:#c0392b;--green:#2d6a22;--orange:#d4700a;
  --text:#1a2318;--text2:#4a6642;--text3:#8aaa82;
  --shadow:0 1px 3px rgba(0,0,0,0.08),0 2px 8px rgba(0,0,0,0.06);
  --shadow-md:0 4px 16px rgba(0,0,0,0.1),0 2px 6px rgba(0,0,0,0.06);
  --r:7px;--r2:11px;--r3:16px;
  --topbar-h:70px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;}
html,body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text);height:100%;overflow:hidden;-webkit-font-smoothing:antialiased;}

/* AUTH */
.auth-screen{position:fixed;inset:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;background-image:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(45,106,34,0.08) 0%,transparent 70%);}
.auth-box{width:100%;max-width:420px;background:var(--s1);border:1.5px solid var(--border);border-radius:20px;padding:36px 40px;box-shadow:0 12px 50px rgba(0,0,0,0.15),0 2px 10px rgba(0,0,0,0.08);}
.auth-logo{display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:32px;text-align:center;}
.auth-logo-img{width:52px;height:52px;border-radius:14px;object-fit:contain;flex-shrink:0;}
.auth-logo-mark{width:140px;height:102px;background:transparent;border-radius:0;display:grid;place-items:center;flex-shrink:0;border:none;box-shadow:none;overflow:visible;padding:0;}
.auth-logo-text{font-family:'Bebas Neue',sans-serif;font-size:2.6rem;letter-spacing:0.12em;color:var(--text);}
.auth-logo-text span{color:var(--acc-bright);}
.auth-tagline{font-size:0.8rem;color:var(--text3);margin-top:0;font-weight:500;letter-spacing:0.02em;}
.auth-tabs{display:flex;background:var(--s2);border-radius:var(--r);padding:3px;gap:3px;margin-bottom:18px;}
.auth-tab{flex:1;padding:8px;border-radius:6px;border:none;background:transparent;color:var(--text2);font-family:'DM Sans',sans-serif;font-size:0.82rem;font-weight:600;cursor:pointer;transition:all 0.15s;}
.auth-tab.active{background:var(--s3);color:var(--acc-bright);}
.afield{margin-bottom:10px;}
.afield label{display:block;font-size:0.74rem;font-weight:700;color:var(--text2);margin-bottom:5px;text-transform:uppercase;letter-spacing:0.07em;}
.afield input{width:100%;background:var(--s2);border:1px solid var(--border2);border-radius:var(--r);color:var(--text);font-family:'Figtree',sans-serif;font-size:0.88rem;padding:10px 12px;outline:none;transition:border-color 0.15s,box-shadow 0.15s;}
.afield input:focus{border-color:var(--acc);box-shadow:0 0 0 3px var(--acc-glow);}
.auth-btn{width:100%;padding:13px;background:var(--acc);color:#fff;border:none;border-radius:var(--r);font-family:'DM Sans',sans-serif;font-size:0.92rem;font-weight:700;cursor:pointer;margin-top:10px;transition:all 0.15s;display:flex;align-items:center;justify-content:center;gap:8px;}
.auth-btn:hover{background:var(--acc-light);transform:translateY(-1px);}
.auth-btn:disabled{opacity:0.5;cursor:not-allowed;transform:none;}
.auth-msg{padding:10px 12px;border-radius:var(--r);font-size:0.78rem;margin-bottom:10px;display:none;}
.auth-msg.err{background:rgba(255,89,89,0.1);border:1px solid rgba(255,89,89,0.3);color:var(--red);}
.auth-msg.ok{background:rgba(109,184,96,0.1);border:1px solid rgba(109,184,96,0.3);color:var(--green);}
.auth-msg.show{display:block;}

/* TOPBAR */
.topbar{
  height:var(--topbar-h);
  background:rgba(245,241,234,0.92);
  backdrop-filter:blur(28px) saturate(200%);
  -webkit-backdrop-filter:blur(28px) saturate(200%);
  border-bottom:1px solid rgba(191,185,175,0.55);
  display:flex;align-items:center;padding:0 20px;gap:12px;
  position:fixed;top:0;left:0;right:0;z-index:200;
  box-shadow:0 1px 0 rgba(255,255,255,0.7) inset, 0 2px 24px rgba(42,94,30,0.08);
  transition:background 0.3s,box-shadow 0.3s;
}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;white-space:nowrap;flex-shrink:0;}
.logo-mark{width:48px;height:36px;display:grid;place-items:center;flex-shrink:0;overflow:visible;background:transparent;box-shadow:none;border:none;border-radius:0;}
.logo-mark img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 1px 3px rgba(42,94,30,0.18));}
.logo-wordmark{display:flex;flex-direction:column;line-height:1;}
.logo-name{font-family:'Bebas Neue',sans-serif;font-size:1.75rem;letter-spacing:0.09em;color:var(--text);line-height:1;}
.logo-domain{font-family:'DM Sans',sans-serif;font-size:0.58rem;color:var(--acc-light);font-weight:700;letter-spacing:0.16em;text-transform:uppercase;margin-top:3px;}
.logo-co{font-size:0.72rem;color:var(--text3);font-weight:500;margin-left:2px;}
.tsep{width:1px;height:22px;background:var(--border);flex-shrink:0;margin:0 2px;}

/* Nav pills — centered, constrained, premium feel */
.tcenter{
  flex:1;display:flex;align-items:center;gap:3px;
  min-width:0;max-width:380px;
  background:var(--s2);border-radius:12px;padding:5px;
  border:1px solid var(--border);
  box-shadow:inset 0 1px 3px rgba(0,0,0,0.04);
}
.tright{display:flex;align-items:center;gap:7px;flex-shrink:0;margin-left:auto;}
.nb{
  flex:1;padding:9px 18px;border-radius:8px;border:none;
  background:transparent;color:var(--text2);
  font-family:'DM Sans',sans-serif;font-size:0.88rem;font-weight:500;
  cursor:pointer;
  transition:background 0.25s cubic-bezier(0.34,1.2,0.64,1), color 0.25s ease, box-shadow 0.25s ease, transform 0.18s cubic-bezier(0.34,1.2,0.64,1);
  white-space:nowrap;display:flex;align-items:center;justify-content:center;gap:6px;
  line-height:1;
}
.nb:hover{
  background:var(--s1);color:var(--text);
  transform:translateY(-0.5px);
  box-shadow:0 1px 5px rgba(0,0,0,0.07);
}
.nb:active{transform:translateY(0);box-shadow:none;}
.nb.active{
  background:var(--acc);color:#fff;font-weight:700;
  box-shadow:0 3px 12px rgba(42,94,30,0.34),0 1px 3px rgba(42,94,30,0.2),inset 0 1px 0 rgba(255,255,255,0.12);
  transform:translateY(-0.5px);
}
.nb.active:hover{background:var(--acc-light);transform:translateY(-1px);box-shadow:0 5px 16px rgba(42,94,30,0.38),0 2px 4px rgba(42,94,30,0.22),inset 0 1px 0 rgba(255,255,255,0.15);}

/* Chips - cleaner look */
.chip{
  padding:5px 10px;border-radius:20px;
  border:1.5px solid var(--border);
  font-family:'JetBrains Mono',monospace;font-size:0.64rem;
  color:var(--text2);background:var(--s1);
  white-space:nowrap;font-weight:600;
  letter-spacing:0.02em;
}
.chip.hi{
  color:var(--acc);border-color:rgba(42,94,30,0.35);
  background:var(--acc-dim);font-weight:700;
  box-shadow:0 0 0 1px rgba(42,94,30,0.08);
}

/* User button */
.user-btn{
  display:flex;align-items:center;gap:7px;
  cursor:pointer;padding:4px 8px 4px 4px;
  border-radius:24px;background:var(--s2);
  border:1.5px solid var(--border);
  transition:all 0.15s;max-width:190px;
}
.user-btn:hover{border-color:var(--acc);background:var(--s1);box-shadow:0 2px 8px rgba(42,94,30,0.12);}
.user-av{
  width:32px;height:32px;border-radius:50%;
  background:var(--acc);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:0.88rem;font-weight:700;flex-shrink:0;
  ring:2px solid rgba(255,255,255,0.4);
  box-shadow:0 0 0 2px rgba(42,94,30,0.2);
}
.user-nm{font-size:0.76rem;font-weight:600;color:var(--text);}

/* LAYOUT */
.app{display:grid;grid-template-columns:320px 1fr 320px;height:100vh;padding-top:var(--topbar-h);overflow:hidden;}
.panel{display:flex;flex-direction:column;overflow:hidden;height:100%;min-height:0;}
.p-left{background:var(--s1);border-right:1px solid var(--border);}
.p-center{background:#d5cfc3;}
.p-right{background:var(--s1);border-left:1px solid var(--border);}
.scroll{overflow-y:auto;flex:1;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;scroll-behavior:smooth;}
.scroll::-webkit-scrollbar{width:4px;}
.scroll::-webkit-scrollbar-track{background:transparent;}
.scroll::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px;}
.scroll::-webkit-scrollbar-thumb:hover{background:var(--acc);opacity:0.5;}
.ph{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;background:var(--s1);position:sticky;top:0;z-index:10;}
.ph-title{font-size:0.72rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--acc-bright);}

/* ═══ DASHBOARD ══════════════════════════════════════ */
.dash-card{
  background:var(--s1);
  border:1.5px solid var(--border);
  border-radius:var(--r2);
  padding:20px;
  box-shadow:var(--shadow);
  transition:box-shadow 0.2s,border-color 0.2s;
}
.dash-card:hover{box-shadow:var(--shadow-md);border-color:var(--border2);}
.dash-kpi{font-size:2.2rem;font-weight:800;color:var(--text);line-height:1;letter-spacing:-0.02em;}
.dash-label{font-size:0.75rem;color:var(--text3);margin-top:5px;font-weight:700;text-transform:uppercase;letter-spacing:0.07em;}
.dash-sub{font-size:0.72rem;color:var(--acc);margin-top:3px;font-weight:700;}
.dash-section-title{font-size:0.68rem;font-weight:800;letter-spacing:0.1em;text-transform:uppercase;color:var(--text3);}
.dash-loading{font-size:0.8rem;color:var(--text3);padding:12px 0;}
.dash-bar{
  background:var(--acc);border-radius:5px 5px 0 0;flex:1;min-width:0;
  transition:height 0.4s cubic-bezier(0.34,1.2,0.64,1),opacity 0.15s;
  position:relative;cursor:default;opacity:0.75;
}
.dash-bar:hover{opacity:1;}
.dash-bar-label{position:absolute;bottom:-22px;left:50%;transform:translateX(-50%);font-size:0.6rem;color:var(--text3);white-space:nowrap;font-weight:600;}
.dash-bar-val{position:absolute;top:-20px;left:50%;transform:translateX(-50%);font-size:0.62rem;color:var(--text2);white-space:nowrap;font-weight:700;}
.dash-prod-row{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--border);}
.dash-prod-row:last-child{border-bottom:none;}
.dash-prod-name{flex:1;font-size:0.82rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.dash-prod-bar-wrap{width:70px;background:var(--s3);border-radius:4px;height:5px;flex-shrink:0;}
.dash-prod-bar-fill{background:var(--acc);border-radius:4px;height:5px;transition:width 0.5s cubic-bezier(0.34,1.1,0.64,1);}
.dash-prod-count{font-size:0.78rem;font-weight:800;color:var(--text);min-width:24px;text-align:right;}
.dash-recent-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border);}
.dash-recent-row:last-child{border-bottom:none;}
.dash-dot{width:7px;height:7px;border-radius:50%;background:var(--acc);flex-shrink:0;}
.dash-dot.yellow{background:#f5c842;}
.dash-recent-info{flex:1;min-width:0;}
.dash-recent-name{font-size:0.82rem;font-weight:700;color:var(--text);}
.dash-recent-meta{font-size:0.65rem;color:var(--text3);}
.dash-recent-qty{font-size:0.8rem;font-weight:700;color:var(--text2);font-family:'JetBrains Mono',monospace;}
.dash-prt-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border);}
.dash-prt-row:last-child{border-bottom:none;}
.dash-prt-icon{font-size:1.2rem;}
.dash-prt-info{flex:1;min-width:0;}
.dash-prt-name{font-size:0.82rem;font-weight:700;color:var(--text);}
.dash-prt-ip{font-size:0.67rem;color:var(--text3);font-family:'JetBrains Mono',monospace;}
.dash-status-dot{width:8px;height:8px;border-radius:50%;background:#4caf50;flex-shrink:0;box-shadow:0 0 6px rgba(76,175,80,0.5);}
.dash-status-dot.grey{background:var(--text3);box-shadow:none;}

/* ═══ DATABLAÐ TABS & PDF ════════════════════════════ */
.safn-doc-tab{flex:1;padding:7px 4px;border-radius:8px;border:1.5px solid var(--border);background:var(--s2);color:var(--text2);font-family:'DM Sans',sans-serif;font-size:0.7rem;font-weight:600;cursor:pointer;text-align:center;transition:all 0.15s;white-space:nowrap;}
.safn-doc-tab:hover{transform:translateY(-1px);}
.safn-doc-midi:hover{border-color:var(--acc);color:var(--acc);background:var(--acc-dim);}
.safn-doc-databla:hover{border-color:#1a6fba;color:#1a6fba;background:rgba(26,111,186,0.1);}
.safn-doc-uppskrift:hover{border-color:#7b3fa0;color:#7b3fa0;background:rgba(123,63,160,0.1);}
#databladSheet{position:fixed;inset:0;z-index:9999;background:#fff;overflow-y:auto;}
#uppskriftSheet{position:fixed;inset:0;z-index:99999;overflow-y:auto;}
.upp-ingr-row{display:flex;align-items:center;gap:6px;padding:5px 0;border-bottom:0.5px solid var(--border);}
.upp-ingr-row:last-child{border-bottom:none;}
.upp-ingr-nm{flex:1;font-size:0.78rem;color:var(--text);}
.upp-ingr-kg{width:80px;text-align:right;font-size:0.75rem;font-weight:700;color:var(--text2);font-family:'JetBrains Mono',monospace;}
.upp-ingr-pct{width:44px;text-align:right;font-size:0.7rem;color:var(--text3);}
.upp-ingr-bar{width:36px;height:4px;background:var(--border);border-radius:2px;overflow:hidden;flex-shrink:0;}
.upp-bar-fill{height:100%;border-radius:2px;background:var(--acc);}
.upp-appr-stamp{border-left:4px solid var(--acc);padding:8px 14px;background:var(--s1);border-radius:0 8px 8px 0;border:1px solid var(--border);border-left:4px solid var(--acc);min-width:180px;flex:1;max-width:260px;}

/* ═══ FORM LAYOUT ════════════════════════════════════ */
.fbody{padding:12px;display:flex;flex-direction:column;gap:8px;overflow-x:hidden;}
.fsec{
  padding:0;
  background:var(--s1);
  border-radius:var(--r2);
  border:1.5px solid var(--border);
  display:flex;flex-direction:column;
  box-shadow:0 1px 4px rgba(0,0,0,0.06),0 2px 8px rgba(0,0,0,0.04);
  overflow:hidden;
  transition:box-shadow 0.25s ease,border-color 0.25s ease,transform 0.2s ease;
}
.fsec:hover{border-color:rgba(42,94,30,0.25);}
.fsec:hover{box-shadow:0 3px 12px rgba(0,0,0,0.1),0 6px 20px rgba(0,0,0,0.07);}
.fsec:hover .fsec-title-icon{transform:scale(1.08) rotate(-2deg);transition:transform 0.2s cubic-bezier(0.34,1.4,0.64,1);}
.fsec-title-icon{transition:transform 0.2s cubic-bezier(0.34,1.4,0.64,1);}
.fsec-inner{padding:14px 16px;display:flex;flex-direction:column;gap:10px;animation:fadeSlideIn 0.2s ease;}
@keyframes fadeSlideIn{from{opacity:0;transform:translateY(-4px);}to{opacity:1;transform:translateY(0);}}
@keyframes sectionPop{0%{transform:scale(0.98);opacity:0.7;}100%{transform:scale(1);opacity:1;}}
.fsec{animation:sectionPop 0.25s cubic-bezier(0.34,1.2,0.64,1);}
.fsec-title{
  font-size:0.78rem;font-weight:800;letter-spacing:0.05em;
  text-transform:uppercase;color:var(--acc);
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  padding:13px 16px;
  background:linear-gradient(135deg,rgba(42,94,30,0.07) 0%,rgba(42,94,30,0.02) 100%);
  border-bottom:1.5px solid rgba(42,94,30,0.12);
  user-select:none;
}
.fsec-title-icon{
  width:26px;height:26px;border-radius:8px;
  background:var(--acc);
  color:#fff;
  display:grid;place-items:center;
  font-size:0.9rem;flex-shrink:0;
  box-shadow:0 2px 6px rgba(42,94,30,0.3);
}
.field{display:flex;flex-direction:column;gap:4px;}
.field label{
  font-size:0.72rem;font-weight:700;color:var(--text2);
  letter-spacing:0.04em;text-transform:uppercase;
  display:flex;align-items:center;gap:5px;
  transition:color 0.15s;
}
.field:focus-within label{color:var(--acc);}
.req{
  font-size:0.55rem;color:var(--red);
  background:rgba(192,57,43,0.1);
  padding:1px 5px;border-radius:3px;
  letter-spacing:0;text-transform:none;font-weight:700;
}
.fi,.fi-ta,.fi-sel{
  background:var(--s2);
  border:1.5px solid var(--border);
  border-radius:var(--r);
  color:var(--text);
  font-family:'DM Sans',sans-serif;
  font-size:max(16px,0.88rem);
  padding:9px 12px;
  width:100%;outline:none;
  transition:border-color 0.18s,box-shadow 0.18s,background 0.18s,transform 0.15s;
  -webkit-appearance:none;
  box-shadow:inset 0 1px 3px rgba(0,0,0,0.04);
}
.fi:hover,.fi-ta:hover,.fi-sel:hover{background:var(--s1);border-color:var(--border2);}
.fi:focus,.fi-ta:focus,.fi-sel:focus{
  border-color:var(--acc);
  box-shadow:0 0 0 3px var(--acc-glow),inset 0 1px 3px rgba(0,0,0,0.04);
  background:var(--s1);
  transform:translateY(-1px);
}
.fi::placeholder,.fi-ta::placeholder{color:var(--text3);font-weight:400;font-style:italic;}
.fi-ta{resize:vertical;min-height:54px;line-height:1.6;}
.fi-sel{
  cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238aaa82' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 12px center;
  padding-right:32px;
}
.fi-sel option{background:var(--s2);}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:8px;min-width:0;}
.seg{display:grid;gap:4px;}
.tp-btn{
  border:1.5px solid var(--border);background:var(--s2);color:var(--text2);
  border-radius:9px;padding:8px 4px;font-size:0.7rem;font-family:'DM Sans',sans-serif;
  cursor:pointer;text-align:center;line-height:1.35;transition:all 0.15s;font-weight:600;
  box-shadow:0 1px 3px rgba(0,0,0,0.05);
}
.tp-btn:hover{background:var(--s3);color:var(--text);border-color:var(--border2);transform:translateY(-1px);box-shadow:0 2px 6px rgba(0,0,0,0.1);}
.tp-btn.tp-active{border-color:var(--acc);background:var(--acc-dim);color:var(--acc-bright);font-weight:700;box-shadow:0 0 0 2px var(--acc-glow);}
.tp-btn.tp-cold{border-color:#1ab3d4;background:rgba(26,179,212,0.12);color:#0e90ab;box-shadow:0 0 0 2px rgba(26,179,212,0.2);}
.tp-btn.tp-dry{border-color:#c49a2a;background:rgba(196,154,42,0.12);color:#8B6914;box-shadow:0 0 0 2px rgba(196,154,42,0.2);}
.tp-btn.tp-frozen{border-color:#5a3db0;background:rgba(90,61,176,0.13);color:#4a2da0;box-shadow:0 0 0 2px rgba(90,61,176,0.2);}
.tp-btn.tp-deep{border-color:#3a2090;background:rgba(58,32,144,0.13);color:#2a1070;box-shadow:0 0 0 2px rgba(58,32,144,0.2);}
.seg-btn{
  padding:10px 5px;border-radius:var(--r);
  border:1.5px solid var(--border);
  background:var(--s2);color:var(--text2);
  font-family:'DM Sans',sans-serif;font-size:0.72rem;font-weight:600;
  cursor:pointer;text-align:center;transition:all 0.15s;line-height:1.3;
  box-shadow:0 1px 3px rgba(0,0,0,0.05);
}
.seg-btn:hover{color:var(--text);background:var(--s3);border-color:var(--border2);transform:translateY(-1px);}
.seg-btn.sa{border-color:var(--acc);background:var(--acc-dim);color:var(--acc-bright);font-weight:700;box-shadow:0 0 0 2px var(--acc-glow);}
.seg-btn.sc{border-color:var(--cold);background:var(--cold-dim);color:var(--cold);}
.seg-btn.sf{border-color:var(--frozen);background:var(--frozen-dim);color:var(--frozen);}
.tog-row{display:flex;align-items:center;justify-content:space-between;padding:5px 0;}
.tog-row label{font-size:0.82rem;color:var(--text2);cursor:pointer;user-select:none;}
.tog{width:34px;height:20px;background:var(--s4);border-radius:10px;position:relative;cursor:pointer;transition:background 0.22s;flex-shrink:0;border:1.5px solid var(--border);}
.tog.on{background:var(--acc);border-color:var(--acc);box-shadow:0 0 0 2px var(--acc-glow);}
.tog::after{content:'';position:absolute;width:13px;height:13px;background:#fff;border-radius:50%;top:2px;left:2px;transition:transform 0.22s cubic-bezier(0.34,1.4,0.64,1);box-shadow:0 1px 4px rgba(0,0,0,0.35);}
.tog.on::after{transform:translateX(14px);}
.upload-zone{
  border:2px dashed var(--border2);border-radius:var(--r2);
  padding:14px 12px;text-align:center;cursor:pointer;
  transition:all 0.2s;position:relative;overflow:hidden;
  background:var(--s2);
}
.upload-zone:hover,.upload-zone.drag-over{border-color:var(--acc);background:var(--acc-dim);}
.upload-zone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;}
.img-strip{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px;}
.img-wrap{position:relative;}
.img-thumb{width:48px;height:48px;border-radius:8px;border:1.5px solid var(--border2);object-fit:contain;background:#fff;cursor:pointer;transition:border-color 0.15s,box-shadow 0.15s;padding:2px;}
.img-thumb:hover{border-color:var(--blue);box-shadow:0 2px 8px rgba(26,111,186,0.2);}
.img-del{position:absolute;top:-5px;right:-5px;width:16px;height:16px;background:var(--red);border-radius:50%;border:2px solid var(--s1);color:#fff;font-size:8px;cursor:pointer;display:none;align-items:center;justify-content:center;}
.img-wrap:hover .img-del{display:flex;}

/* ═══ BUTTONS ════════════════════════════════════════ */
.btn{
  padding:11px 14px;border-radius:var(--r);border:none;
  box-sizing:border-box;width:100%;
  font-family:'DM Sans',sans-serif;font-size:0.84rem;font-weight:700;
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:6px;
  transition:all 0.18s cubic-bezier(0.34,1.2,0.64,1);
  letter-spacing:0.01em;overflow:hidden;min-width:0;white-space:nowrap;
  position:relative;
}
.btn-acc{
  background:var(--acc);color:#fff;
  box-shadow:0 2px 8px rgba(42,94,30,0.3),0 1px 2px rgba(0,0,0,0.1);
}
.btn-acc:hover{
  background:var(--acc-light);
  transform:translateY(-2px);
  box-shadow:0 6px 18px rgba(42,94,30,0.38),0 2px 6px rgba(0,0,0,0.1);
}
.btn-acc:active{transform:translateY(0);box-shadow:0 1px 4px rgba(42,94,30,0.3);}
.btn-sec{background:var(--s2);color:var(--text);border:1.5px solid var(--border);}
.btn-sec:hover{border-color:var(--acc);color:var(--acc);background:var(--acc-dim);transform:translateY(-1px);}
.btn-blue{background:var(--blue-dim);color:var(--blue);border:1px solid rgba(26,111,186,0.25);}
.btn-blue:hover{background:rgba(26,111,186,0.18);transform:translateY(-1px);}
.btn-ghost{background:transparent;color:var(--text3);border:1.5px dashed var(--border);font-size:0.78rem;}
.btn-ghost:hover{color:var(--text2);border-color:var(--acc);background:var(--acc-dim);transform:translateY(-1px);}
.btn-row{display:grid;grid-template-columns:1fr 1fr;gap:7px;min-width:0;}

/* CANVAS */

/* ── CANVAS HEADER & TOOLBAR ── */
.canvas-header{height:48px;padding:0 16px;border-bottom:1.5px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;background:var(--s1);position:relative;z-index:5;}
.ctb-bar{padding:5px 10px;border-bottom:1.5px solid var(--border);display:flex;align-items:center;gap:2px;flex-shrink:0;background:var(--s1);overflow-x:auto;overflow-y:hidden;position:relative;z-index:5;-webkit-overflow-scrolling:touch;white-space:nowrap;}
.ctb-bar::-webkit-scrollbar{height:2px;}
.ctb-bar::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px;}
/* Note: .ctb is the old standalone toolbar - keep hidden if not used in current layout */
.ctb{display:none!important;}
.canvas-wrap{flex:1;display:flex;align-items:center;justify-content:center;padding:28px 24px;overflow:auto;position:relative;background:radial-gradient(ellipse 80% 70% at 50% 45%,rgba(42,94,30,0.07) 0%,transparent 65%);}
.canvas-center{display:inline-flex;align-items:center;justify-content:center;min-width:100%;min-height:100%;}
.p-center{background:#d5cfc3;display:flex;flex-direction:column;overflow:hidden;position:relative;z-index:1;}
.p-left{background:var(--s1);border-right:1.5px solid var(--border);position:relative;z-index:2;}
.p-right{background:var(--s1);border-left:1.5px solid var(--border);position:relative;z-index:2;}

/* old canvas */flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;overflow:auto;position:relative;background:radial-gradient(ellipse 70% 60% at 50% 40%,rgba(61,110,50,0.06) 0%,transparent 70%);}
.canvas-center{display:flex;align-items:center;justify-content:center;min-height:100%;min-width:100%;}
.cgrid{position:fixed;inset:0;pointer-events:none;background-image:linear-gradient(rgba(255,255,255,0.01) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,0.01) 1px,transparent 1px);background-size:20px 20px;opacity:0;transition:opacity 0.3s;}
.cgrid.show{opacity:1;}
.ctb{display:flex;gap:3px;margin-bottom:12px;background:var(--s1);border:1.5px solid var(--border);border-radius:var(--r2);padding:5px;flex-shrink:0;flex-wrap:wrap;justify-content:center;box-shadow:var(--shadow);}
.ctool{padding:5px 10px;border-radius:var(--r);border:none;background:transparent;color:var(--text2);font-family:'Figtree',sans-serif;font-size:0.74rem;font-weight:500;cursor:pointer;transition:all 0.15s;white-space:nowrap;}
.ctool:hover{background:var(--s2);color:var(--text);}
.ctool.act{background:var(--acc-dim);color:var(--acc);}
.stage{background:#fff;touch-action:none;box-shadow:0 8px 40px rgba(0,0,0,0.18),0 2px 8px rgba(0,0,0,0.1),0 0 0 1px rgba(0,0,0,0.06);position:relative;overflow:hidden;flex-shrink:0;contain:layout;}
.limg{position:absolute;cursor:move;border:2px dashed transparent;transition:border-color 0.1s;}
.kbs-section{font-size:0.6rem;font-weight:800;text-transform:uppercase;letter-spacing:0.12em;color:var(--acc);margin:12px 0 6px;padding-bottom:4px;border-bottom:1px solid var(--border);}
.kbs-section:first-child{margin-top:0;}
.kbs-row{display:flex;align-items:center;justify-content:space-between;padding:5px 0;border-bottom:1px solid rgba(0,0,0,0.04);}
.kbs-desc{font-size:0.78rem;color:var(--text1);font-weight:500;}
.kbs-keys{display:flex;gap:4px;align-items:center;}
kbd{display:inline-flex;align-items:center;justify-content:center;min-width:26px;height:22px;padding:0 6px;background:var(--s2);border:1px solid var(--border);border-bottom:2px solid var(--border);border-radius:5px;font-size:0.7rem;font-family:'JetBrains Mono',monospace;color:var(--text2);font-weight:600;white-space:nowrap;}
#lbc{position:absolute;cursor:move;box-sizing:border-box;user-select:none;}
.bfp-opt{display:flex;flex-direction:column;align-items:center;gap:3px;padding:5px 3px 4px;border:1.5px solid var(--border);border-radius:7px;cursor:pointer;background:var(--s2);transition:all 0.13s;font-size:0.55rem;font-weight:600;color:var(--text2);}
.bfp-opt:hover{border-color:#2a5e1e;background:rgba(42,94,30,0.08);color:#2a5e1e;}
.bfp-opt.bfp-sel{border-color:#2a5e1e;background:rgba(42,94,30,0.1);color:#2a5e1e;}
#lbc .rh{position:absolute;bottom:-4px;right:-4px;width:10px;height:10px;background:#2a5e1e;border-radius:2px;cursor:se-resize;z-index:15;opacity:0;}
#lbc:hover .rh{opacity:1;}
.lshape{position:absolute;cursor:move;box-sizing:border-box;}
.lshape-text{line-height:1.4;overflow:visible;}
.lshape .rh{position:absolute;bottom:-4px;right:-4px;width:10px;height:10px;background:#2a5e1e;border-radius:2px;cursor:se-resize;z-index:13;opacity:0;}
.lshape:hover .rh,.lshape.sel .rh{opacity:1;}
#shape-sidebar{position:absolute;left:12px;top:8px;width:clamp(220px,18vw,256px);background:var(--s1);border:1px solid var(--border);border-radius:14px;z-index:50;box-shadow:0 8px 32px rgba(0,0,0,0.15),0 2px 8px rgba(0,0,0,0.08);transform:translateX(-280px) scale(0.97);transition:transform 0.24s cubic-bezier(.4,0,.2,1),opacity 0.2s;pointer-events:none;opacity:0;max-height:calc(100vh - 120px);overflow-y:auto;scrollbar-width:thin;}
#shape-sidebar.sb-open{transform:translateX(0) scale(1);pointer-events:auto;opacity:1;}
.ssb-header{display:flex;align-items:center;justify-content:space-between;padding:11px 14px 0;}
.ssb-header-title{font-size:0.72rem;font-weight:800;letter-spacing:0.06em;text-transform:uppercase;color:var(--text1);}
.ssb-close{width:22px;height:22px;border:none;background:var(--s2);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text2);font-size:1rem;line-height:1;transition:background 0.12s,color 0.12s;}
.ssb-close:hover{background:rgba(220,38,38,0.12);color:#dc2626;}
.ssb-body{padding:10px 14px 14px;}
.ssb-sec{font-size:0.56rem;font-weight:800;text-transform:uppercase;letter-spacing:0.12em;color:var(--text3);margin:12px 0 8px;padding-bottom:5px;border-bottom:1px solid var(--border);}
.ssb-sec:first-child{margin-top:0;}
.ssb-grid{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin-bottom:4px;}
.ssb-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;padding:clamp(8px,1.2vh,13px) 4px clamp(7px,1vh,11px);border:1.5px solid var(--border);border-radius:9px;cursor:pointer;color:var(--text2);font-size:0.63rem;font-weight:700;transition:border-color 0.15s,background 0.15s,transform 0.12s,color 0.15s;background:var(--s2);user-select:none;}
.ssb-item:hover{border-color:#2a5e1e;background:rgba(42,94,30,0.09);color:#2a5e1e;transform:translateY(-2px);}
.ssb-item:active{transform:translateY(0) scale(0.97);}
.ssb-item svg{transition:transform 0.15s;}
.ssb-item:hover svg{transform:scale(1.08);}
.ssb-divider{height:1px;background:var(--border);margin:11px 0;}
.ssb-hint{font-size:0.68rem;color:var(--text3);font-style:italic;padding:8px 0;text-align:center;}
.ssb-prop-row{display:flex;align-items:center;gap:7px;margin-bottom:8px;}
.ssb-prop-lbl{font-size:0.64rem;color:var(--text2);min-width:42px;flex-shrink:0;font-weight:700;}
.ssb-prop-row input[type=color]{width:28px;height:24px;border:1.5px solid var(--border);border-radius:5px;cursor:pointer;padding:1px 2px;transition:transform 0.12s;}
.ssb-prop-row input[type=color]:hover{transform:scale(1.08);}
.ssb-chk-lbl{font-size:0.63rem;color:var(--text2);display:flex;align-items:center;gap:3px;cursor:pointer;white-space:nowrap;}
.ssb-stepper{display:flex;align-items:center;gap:0;flex:1;min-width:0;border:1px solid var(--border);border-radius:7px;overflow:hidden;background:var(--s2);}
.ssb-stepper button{width:26px;height:26px;border:none;background:transparent;cursor:pointer;font-size:1rem;font-weight:700;color:var(--text2);display:flex;align-items:center;justify-content:center;transition:background 0.1s,color 0.1s;flex-shrink:0;}
.ssb-stepper button:hover{background:rgba(42,94,30,0.12);color:#2a5e1e;}
.ssb-stepper button:active{background:rgba(42,94,30,0.2);}
.ssb-stepper-val{flex:1;text-align:center;font-size:0.72rem;font-weight:700;color:var(--text1);padding:0 2px;cursor:default;user-select:none;}
.ssb-stepper-sep{width:1px;background:var(--border);height:18px;flex-shrink:0;}
.ssb-toggle-row{display:flex;gap:5px;flex:1;}
.ssb-tog{flex:1;padding:4px 2px;border:1.5px solid var(--border);border-radius:6px;background:var(--s2);color:var(--text2);font-size:0.75rem;cursor:pointer;transition:all 0.12s;text-align:center;line-height:1;}
.ssb-tog:hover{border-color:#2a5e1e;color:#2a5e1e;}
.ssb-tog.on{background:#2a5e1e;border-color:#2a5e1e;color:#fff;}
.ssb-del-btn{width:100%;padding:7px;background:transparent;border:1.5px solid #fca5a5;border-radius:8px;color:#dc2626;font-size:0.7rem;cursor:pointer;margin-top:6px;font-weight:700;transition:all 0.14s;letter-spacing:0.03em;}
.ssb-del-btn:hover{background:#fef2f2;border-color:#ef4444;}
.limg:hover{border-color:rgba(79,158,255,0.5);}
.limg.sel{border-color:#4f9eff;}
.limg img{width:100%;height:100%;object-fit:contain;display:block;pointer-events:none;}
.rh{position:absolute;bottom:-4px;right:-4px;width:12px;height:12px;background:#4f9eff;border-radius:2px;cursor:nwse-resize;}

/* RIGHT */
.rtabs{display:flex;border-bottom:1.5px solid var(--border);flex-shrink:0;background:var(--s2);padding:4px 8px 0;gap:2px;}
.rtab{flex:1;padding:10px 5px;border:none;background:transparent;color:var(--text2);font-family:'DM Sans',sans-serif;font-size:0.78rem;font-weight:700;cursor:pointer;border-bottom:2.5px solid transparent;transition:all 0.15s;border-radius:var(--r) var(--r) 0 0;letter-spacing:0.01em;}
.rtab:hover{color:var(--text);background:var(--s3);}
.rtab.active{color:var(--acc);border-bottom-color:var(--acc);background:var(--s1);}
.rbody{padding:12px;display:flex;flex-direction:column;gap:10px;}
.tcard{background:var(--s1);border:1.5px solid var(--border);border-radius:var(--r2);overflow:hidden;transition:border-color 0.2s,transform 0.2s,box-shadow 0.2s;margin-bottom:8px;box-shadow:var(--shadow);}
.tcard:hover{border-color:var(--acc);transform:translateY(-2px);box-shadow:var(--shadow-md);}
.tcard-prev{height:76px;background:#fff;overflow:hidden;display:flex;align-items:center;justify-content:center;cursor:pointer;}
.tcard-info{padding:8px 10px;}
.tcard-name{font-size:0.8rem;font-weight:600;margin-bottom:2px;}
.tcard-meta{font-size:0.65rem;color:var(--text2);font-family:'JetBrains Mono',monospace;}
.tcard-acts{display:flex;gap:4px;margin-top:6px;}
.mbtn{font-size:0.64rem;padding:3px 7px;border-radius:4px;border:1px solid var(--border2);background:transparent;color:var(--text2);cursor:pointer;font-family:'Figtree',sans-serif;font-weight:500;transition:all 0.15s;}
.mbtn:hover{color:var(--acc-bright);border-color:var(--acc);}
.mbtn.d:hover{color:var(--red);border-color:var(--red);}
.share-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;}
.share-btn{padding:12px 8px;border-radius:var(--r2);border:1.5px solid var(--border);background:var(--s2);color:var(--text);cursor:pointer;font-family:'Figtree',sans-serif;font-size:0.74rem;font-weight:500;text-align:center;transition:all 0.15s;display:flex;flex-direction:column;align-items:center;gap:4px;}
.share-btn span{font-size:1.2rem;}
.share-btn:hover{border-color:var(--acc);color:var(--acc);background:var(--acc-dim);}
.zpl-box{background:#1a2318;border:1.5px solid var(--border);border-radius:var(--r);padding:10px;max-height:180px;overflow-y:auto;}
.zpl-pre{font-family:'JetBrains Mono',monospace;font-size:0.62rem;color:#7dc46a;white-space:pre-wrap;line-height:1.7;}
.pc{padding:12px 14px;border-radius:var(--r2);border:1.5px solid var(--border);background:var(--s2);cursor:pointer;transition:all 0.2s;display:flex;align-items:center;gap:10px;margin-bottom:6px;box-shadow:var(--shadow);position:relative;}
.pc:hover{border-color:var(--acc);background:var(--s1);transform:translateY(-1px);box-shadow:0 3px 10px rgba(0,0,0,0.08);}
.pc.sel{border-color:var(--acc);background:var(--acc-dim);animation:pcPulse 2.4s ease-in-out infinite;}
@keyframes pcPulse{
  0%,100%{box-shadow:0 0 0 2px var(--acc-glow),0 0 0 0 rgba(42,94,30,0.35);}
  50%{box-shadow:0 0 0 2px var(--acc-glow),0 0 0 6px rgba(42,94,30,0);}
}
.cat-label{font-size:0.6rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--text3);margin-bottom:5px;padding-left:2px;}
.empty{text-align:center;padding:2.5rem 1rem;color:var(--text3);font-size:0.8rem;line-height:1.9;}

/* MODAL */
.modal-bg{position:fixed;inset:0;padding-top:calc(var(--topbar-h) + 10px);background:rgba(15,30,12,0.0);backdrop-filter:blur(0px);-webkit-backdrop-filter:blur(0px);z-index:500;display:none;align-items:flex-start;justify-content:center;padding:calc(var(--topbar-h) + 10px) 20px 20px;transition:background 0.28s ease,backdrop-filter 0.28s ease;}
.modal-bg.show{display:flex;background:rgba(15,30,12,0.45);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);}
.modal-bg.show .modal{animation:modalSlideIn 0.32s cubic-bezier(0.34,1.56,0.64,1) both;}
.modal{background:var(--s1);border:1.5px solid var(--border);border-radius:var(--r3);padding:22px;width:480px;max-width:calc(100vw - 24px);max-height:calc(100vh - 120px);box-shadow:0 20px 60px rgba(0,0,0,0.15),0 4px 16px rgba(0,0,0,0.08);overflow-y:auto;-webkit-overflow-scrolling:touch;}
.modal-title{font-family:'Syne',sans-serif;font-weight:700;font-size:1.05rem;margin-bottom:14px;display:flex;align-items:center;justify-content:space-between;}
.mcl{background:none;border:none;color:var(--text2);font-size:1.2rem;cursor:pointer;}
.mcl:hover{color:var(--text);}

/* USER MENU */
.umenu{position:fixed;top:66px;right:16px;background:var(--s1);border:1.5px solid var(--border);border-radius:var(--r2);padding:8px;z-index:300;min-width:200px;box-shadow:0 8px 30px rgba(0,0,0,0.12),0 2px 8px rgba(0,0,0,0.06);}
.umenu-item{display:block;width:100%;text-align:left;padding:8px 10px;border-radius:6px;border:none;background:transparent;color:var(--text2);font-family:'DM Sans',sans-serif;font-size:0.8rem;cursor:pointer;transition:all 0.15s;}
.umenu-item:hover{background:var(--acc-dim);color:var(--acc);}
.umenu-item.danger:hover{color:var(--red);}



/* ADMIN TABS */
.adm-tab{flex:1;padding:8px 5px;border-radius:6px;border:none;background:transparent;color:var(--text2);font-family:'Figtree',sans-serif;font-size:0.74rem;font-weight:600;cursor:pointer;transition:all 0.15s;display:flex;align-items:center;justify-content:center;gap:4px;}
.adm-tab:hover{background:var(--s3);color:var(--text);}
.adm-tab.active{background:var(--s1);color:var(--acc);box-shadow:0 1px 4px rgba(0,0,0,0.2);}

/* MIÐASAFN */
.safn-cat-btn{padding:5px 12px;border-radius:16px;border:1.5px solid var(--border);background:var(--s3);color:var(--text2);font-family:'DM Sans',sans-serif;font-size:0.76rem;font-weight:600;cursor:pointer;transition:all 0.15s;}
.safn-cat-btn:hover{border-color:var(--acc);color:var(--acc);background:var(--acc-dim);}
.safn-cat-btn.multi-flokk::after{content:'●';font-size:0.45rem;color:var(--acc);margin-left:5px;vertical-align:middle;}
.safn-cat-btn.active{border-color:var(--acc);background:var(--acc-dim);color:var(--acc);}

.stat-box{background:var(--s1);border:1.5px solid var(--border);border-radius:var(--r2);padding:10px 14px;min-width:100px;box-shadow:var(--shadow);}
.stat-box .sv{font-family:'Bebas Neue',sans-serif;font-size:1.6rem;color:var(--acc);line-height:1;}
.stat-box .sl{font-size:0.68rem;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;color:var(--text3);margin-top:1px;}

.adj-btn{width:26px;height:26px;border-radius:6px;border:1.5px solid var(--border);background:var(--s3);color:var(--text);font-size:0.9rem;cursor:pointer;display:grid;place-items:center;flex-shrink:0;transition:all 0.1s;font-weight:700;line-height:1;}
.adj-btn:hover{border-color:var(--acc);color:var(--acc);background:var(--acc-dim);}


/* CANVAS TOOLBAR GROUPS */
.ctb-group{display:flex;gap:2px;}
.ctb-sep{width:1px;height:20px;background:var(--border);margin:0 4px;flex-shrink:0;align-self:center;}
.ctool.active-green{color:var(--acc);background:var(--acc-dim);}
.ctool:hover{background:var(--s3);color:var(--text);}

/* RULER */
.ruler-h{position:absolute;top:0;left:0;right:0;height:20px;background:var(--s1);border-bottom:1px solid var(--border);z-index:5;display:none;overflow:hidden;}
.ruler-v{position:absolute;top:0;left:0;bottom:0;width:20px;background:var(--s1);border-right:1px solid var(--border);z-index:5;display:none;overflow:hidden;}
.ruler-active .ruler-h,.ruler-active .ruler-v{display:block;}
.ruler-active .stage{margin-top:20px;margin-left:20px;}

/* DRAG ELEMENT handles */
.elem-handle{position:absolute;cursor:move;border:1.5px dashed transparent;border-radius:3px;transition:border-color 0.1s;user-select:none;}
.elem-handle:hover{border-color:rgba(45,106,34,0.5);}
.elem-handle.sel{border-color:var(--acc);box-shadow:0 0 0 2px var(--acc-glow);}
.elem-handle .resize-br{position:absolute;bottom:-5px;right:-5px;width:10px;height:10px;background:var(--acc);border-radius:2px;cursor:nwse-resize;z-index:2;}
.elem-handle .elem-del{position:absolute;top:-10px;right:-10px;width:18px;height:18px;background:var(--red);border-radius:50%;border:none;color:#fff;font-size:10px;cursor:pointer;display:none;align-items:center;justify-content:center;z-index:3;}
.elem-handle:hover .elem-del,.elem-handle.sel .elem-del{display:flex;}

/* SNAP GUIDES */
.snap-guide-h{position:absolute;left:0;right:0;height:1px;background:rgba(45,106,34,0.7);pointer-events:none;z-index:20;}
.snap-guide-v{position:absolute;top:0;bottom:0;width:1px;background:rgba(45,106,34,0.7);pointer-events:none;z-index:20;}

/* BG IMAGE overlay */
.stage-bg{position:absolute;inset:0;z-index:0;overflow:hidden;pointer-events:none;}
.stage-bg img{width:100%;height:100%;object-fit:cover;}

/* AUDIT TRAIL */
.audit-row{padding:8px 12px;border-bottom:1px solid var(--border);display:flex;gap:10px;align-items:flex-start;}
.audit-row:last-child{border-bottom:none;}
.audit-icon{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;font-size:0.75rem;flex-shrink:0;background:var(--s3);}
.audit-info{flex:1;min-width:0;}
.audit-action{font-size:0.78rem;font-weight:600;color:var(--text);}
.audit-meta{font-size:0.66rem;color:var(--text3);margin-top:2px;}

/* FONT SELECTOR */
.font-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px;margin-top:4px;}
.font-opt{padding:5px 10px;border-radius:6px;border:1.5px solid var(--border);background:var(--s2);cursor:pointer;font-size:0.78rem;text-align:center;transition:all 0.15s;white-space:nowrap;}
.font-opt.sel{border-color:var(--acc);background:var(--acc-dim);color:var(--acc);}
.font-opt:hover{border-color:var(--acc-light);}


/* ═══ DARK MODE ═══════════════════════════════════════ */
[data-theme="dark"]{
  --bg:#141414;
  --s1:#1c1c1c;
  --s2:#242424;
  --s3:#2e2e2e;
  --s4:#383838;
  --border:#323232;
  --border2:#444;
  --text:#f0ece4;
  --text2:#b8b4ac;
  --text3:#6a6660;
  --acc:#4a9e35;
  --acc-dim:rgba(74,158,53,0.14);
  --acc-glow:rgba(74,158,53,0.22);
  --acc-light:#5ab840;
  --shadow:0 2px 8px rgba(0,0,0,0.45);
  --shadow-md:0 6px 20px rgba(0,0,0,0.55);
}
[data-theme="dark"] .p-center{background:#0f0f0f!important;}
[data-theme="dark"] .stage{box-shadow:0 8px 40px rgba(0,0,0,0.65)!important;}
[data-theme="dark"] .topbar{
  background:rgba(18,18,18,0.88)!important;
  backdrop-filter:blur(24px) saturate(200%)!important;
  -webkit-backdrop-filter:blur(24px) saturate(200%)!important;
  border-bottom:1px solid rgba(255,255,255,0.07)!important;
  box-shadow:0 1px 0 rgba(255,255,255,0.04) inset, 0 2px 24px rgba(0,0,0,0.55)!important;
}
[data-theme="dark"] .tcenter{background:rgba(255,255,255,0.04)!important;border-color:rgba(255,255,255,0.07)!important;}
[data-theme="dark"] .nb:hover{background:rgba(255,255,255,0.08)!important;}
[data-theme="dark"] .user-btn{background:rgba(255,255,255,0.05)!important;border-color:rgba(255,255,255,0.08)!important;}
[data-theme="dark"] .user-btn:hover{background:rgba(255,255,255,0.09)!important;border-color:rgba(42,94,30,0.5)!important;}
[data-theme="dark"] .topbar-share-btn{background:rgba(255,255,255,0.05)!important;border-color:rgba(255,255,255,0.08)!important;color:rgba(255,255,255,0.7)!important;}
[data-theme="dark"] .topbar-share-btn:hover{background:rgba(255,255,255,0.09)!important;border-color:rgba(42,94,30,0.5)!important;color:#fff!important;}
[data-theme="dark"] .topbar-sep{background:rgba(255,255,255,0.1)!important;}
[data-theme="dark"] .auth-box{background:#1c1c1c!important;}
[data-theme="dark"] .auth-screen{background:#111!important;}
[data-theme="dark"] .fi,[data-theme="dark"] .fi-ta,[data-theme="dark"] .fi-sel{
  background:#2a2a2a!important;border-color:#3a3a3a!important;color:#f0ece4!important;
}
[data-theme="dark"] .fi:hover,[data-theme="dark"] .fi-ta:hover,[data-theme="dark"] .fi-sel:hover{
  background:#333!important;
}
[data-theme="dark"] .lpa-new{
  background:linear-gradient(135deg,#242424 0%,#2e2e2e 100%);color:#7a7670;
}
[data-theme="dark"] .lpa-new:hover{
  background:linear-gradient(135deg,#2e2e2e 0%,#383838 100%);color:var(--acc);
}
[data-theme="dark"] .lp-actions{border-bottom-color:#323232;}
[data-theme="dark"] .lp-top{background:#1c1c1c;}
[data-theme="dark"] .rbar{background:#1c1c1c;border-bottom-color:#323232;}
[data-theme="dark"] .rb-save{background:linear-gradient(135deg,#2a5e1e 0%,#357a26 100%);}
[data-theme="dark"] .modal-bg.show{background:rgba(0,0,0,0.65);}
[data-theme="dark"] .print-preview-img{box-shadow:0 8px 40px rgba(0,0,0,0.65);}
[data-theme="dark"] .canvas-wrap{
  background:
    radial-gradient(ellipse 80% 70% at 50% 45%,rgba(74,158,53,0.07) 0%,transparent 65%),
    repeating-linear-gradient(0deg,transparent,transparent 24px,rgba(255,255,255,0.02) 24px,rgba(255,255,255,0.02) 25px),
    repeating-linear-gradient(90deg,transparent,transparent 24px,rgba(255,255,255,0.02) 24px,rgba(255,255,255,0.02) 25px);
}
[data-theme="dark"] .safn-card{background:#1c1c1c;}
[data-theme="dark"] .safn-preview-clean{background:#141414;}
[data-theme="dark"] .safn-img-wrap{background:#2a2a2a;}
[data-theme="dark"] .upload-zone{background:#242424;}


/* ═══ TRANSITIONS — smooth everything ═════════════════ */
*{transition:background-color 0.2s ease, border-color 0.2s ease, color 0.15s ease;}
.stage *{transition:none!important;}
.stage{transition:box-shadow 0.3s ease!important;}

/* ═══ ANIMATIONS ════════════════════════════════════════ */
@keyframes pulse{
  0%,100%{opacity:1;transform:scale(1);}
  50%{opacity:0.7;transform:scale(0.92);}
}
@keyframes popIn{
  0%{transform:scale(0.85);opacity:0;}
  70%{transform:scale(1.05);}
  100%{transform:scale(1);opacity:1;}
}
@keyframes slideUp{
  0%{transform:translateY(20px);opacity:0;}
  100%{transform:translateY(0);opacity:1;}
}
@keyframes slideInLeft{
  0%{transform:translateX(-100%);opacity:0;}
  100%{transform:translateX(0);opacity:1;}
}
@keyframes slideInRight{
  0%{transform:translateX(100%);opacity:0;}
  100%{transform:translateX(0);opacity:1;}
}
@keyframes fadeIn{
  0%{opacity:0;}
  100%{opacity:1;}
}
@keyframes printSuccess{
  0%{transform:scale(1);}
  20%{transform:scale(0.96);}
  50%{transform:scale(1.04);box-shadow:0 0 0 8px rgba(74,158,53,0.3);}
  100%{transform:scale(1);box-shadow:none;}
}
@keyframes spin{
  0%{transform:rotate(0deg);}
  100%{transform:rotate(360deg);}
}

/* Loading pulse */
.loading-pulse{animation:pulse 1.4s ease-in-out infinite;}
.pop-in{animation:popIn 0.3s cubic-bezier(0.34,1.56,0.64,1) forwards;}
.slide-up{animation:slideUp 0.3s ease forwards;}
.fade-in{animation:fadeIn 0.25s ease forwards;}
.panel-left-anim{animation:slideInLeft 0.25s ease forwards;}
.panel-right-anim{animation:slideInRight 0.25s ease forwards;}

/* Print success flash */
.stage.print-flash{animation:printSuccess 0.6s ease forwards;}

/* Skeleton loading */
.skeleton{background:linear-gradient(90deg,var(--s2) 25%,var(--s3) 50%,var(--s2) 75%);background-size:200% 100%;animation:skeletonWave 1.4s ease infinite;}
@keyframes skeletonWave{
  0%{background-position:200% 0;}
  100%{background-position:-200% 0;}
}

/* Dark mode toggle button */
.dm-toggle{width:36px;height:36px;border-radius:50%;border:1.5px solid var(--border);background:var(--s2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:all 0.2s;flex-shrink:0;}
.dm-toggle:hover{border-color:var(--acc);background:var(--acc-dim);}

/* Template gallery */
.tmpl-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px;padding:16px;}
.tgallery-card{background:var(--s2);border:2px solid var(--border);border-radius:12px;cursor:pointer;overflow:hidden;transition:all 0.2s;display:flex;flex-direction:column;}
.tgallery-card:hover{border-color:var(--acc);transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,0.12);}
.tgallery-card.sel{border-color:var(--acc);box-shadow:0 0 0 3px var(--acc-dim);}
.tgallery-preview{width:100%;aspect-ratio:2/3;background:#fff;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:0.6rem;color:#666;position:relative;}
.tgallery-preview iframe{width:300%;height:300%;transform:scale(0.333);transform-origin:top left;pointer-events:none;border:none;}
.tgallery-info{padding:10px;border-top:1px solid var(--border);}
.tgallery-name{font-size:0.78rem;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.tgallery-meta{font-size:0.66rem;color:var(--text3);margin-top:2px;}
.tgallery-actions{display:flex;gap:4px;margin-top:8px;}
.tgallery-actions button{flex:1;padding:5px;border-radius:6px;border:1px solid var(--border);background:var(--s3);color:var(--text2);font-size:0.68rem;cursor:pointer;transition:all 0.15s;}
.tgallery-actions button:hover{border-color:var(--acc);color:var(--acc);}
.tgallery-actions button.load-btn{background:var(--acc);color:#fff;border-color:var(--acc);}
.tgallery-actions button.load-btn:hover{background:var(--acc-light);}


/* ═══ SAFN MODAL ══════════════════════════════════════ */
.safn-panel{
  width:100%;max-width:900px;height:100vh;max-height:100vh;
  background:var(--s1);display:flex;flex-direction:column;
  box-shadow:-8px 0 40px rgba(0,0,0,0.18);
  margin-left:auto;
  padding-top:var(--topbar-h);
  animation:safnSlideIn 0.32s cubic-bezier(0.34,1.2,0.64,1) forwards;
}
@keyframes safnSlideIn{
  0%{transform:translateX(100%);opacity:0;}
  100%{transform:translateX(0);opacity:1;}
}
.safn-header{
  padding:16px 24px;border-bottom:1.5px solid var(--border);
  display:flex;align-items:center;gap:12px;flex-shrink:0;
  background:var(--s1);flex-wrap:wrap;
}
.safn-search-bar{
  display:flex;gap:8px;align-items:center;flex:1;min-width:200px;
}
.safn-cats{
  padding:12px 28px;border-bottom:1px solid var(--border);
  display:flex;gap:6px;align-items:center;flex-wrap:wrap;
  background:var(--s2);flex-shrink:0;overflow-x:auto;
}
.safn-cat-btn{
  padding:5px 14px;border-radius:20px;border:1.5px solid var(--border);
  background:var(--s3);color:var(--text2);font-family:'DM Sans',sans-serif;
  font-size:0.74rem;font-weight:600;cursor:pointer;
  transition:all 0.15s;white-space:nowrap;
}
.safn-cat-btn:hover{border-color:var(--acc);color:var(--acc);}
.safn-cat-btn.active{
  background:var(--acc);color:#fff;border-color:var(--acc);
  box-shadow:0 2px 8px var(--acc-glow);
}
.safn-stats{
  display:flex;gap:16px;padding:12px 28px;
  border-bottom:1px solid var(--border);flex-shrink:0;
  background:var(--s1);
}
.safn-stat{
  display:flex;flex-direction:column;
}
.safn-stat-v{font-size:1.2rem;font-weight:800;color:var(--acc);font-family:'Bebas Neue',sans-serif;letter-spacing:0.05em;line-height:1;}
.safn-stat-l{font-size:0.62rem;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;color:var(--text3);}

/* ═══ SAFN GALLERY ════════════════════════════════════ */
.safn-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:14px;padding:18px 22px;
}
@media(max-width:600px){.safn-grid{grid-template-columns:repeat(2,1fr);gap:10px;padding:12px;}}
@media(max-width:380px){.safn-grid{grid-template-columns:1fr;padding:10px;}}

.safn-card{
  background:var(--s1);border-radius:14px;overflow:hidden;
  border:1.5px solid var(--border);
  display:flex;flex-direction:column;cursor:pointer;
  transition:transform .18s cubic-bezier(.34,1.3,.64,1),box-shadow .18s,border-color .15s;
  animation:cardPopIn .28s ease backwards;
}
.safn-card:hover{
  transform:translateY(-4px);
  box-shadow:0 12px 32px rgba(0,0,0,.13),0 3px 8px rgba(0,0,0,.07);
  border-color:var(--acc);
}
.safn-card:active{transform:translateY(-1px);}
@keyframes cardPopIn{
  0%{opacity:0;transform:translateY(14px) scale(.96);}
  100%{opacity:1;transform:translateY(0) scale(1);}
}

/* ── Image preview (when vörumynd exists) ── */
.safn-img-wrap{
  position:relative;width:100%;overflow:hidden;flex-shrink:0;
  background:#111;
  aspect-ratio:1/1;
}
[data-theme="dark"] .safn-img-wrap{background:#0a0a0a;}
.safn-img-wrap img{
  width:100%;height:100%;object-fit:cover;
  display:block;
  transition:transform 0.4s ease;
}
.safn-card:hover .safn-img-wrap img{transform:scale(1.04);}
.safn-img-grad{
  position:absolute;bottom:0;left:0;right:0;
  background:linear-gradient(to top,rgba(0,0,0,0.88) 0%,rgba(0,0,0,0.5) 40%,transparent 100%);
  padding:40px 14px 12px;
}
.safn-img-name{
  font-size:17px;font-weight:900;color:#fff;line-height:1.2;
  text-shadow:0 2px 6px rgba(0,0,0,0.6);
  letter-spacing:-0.01em;
  overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
  margin-bottom:7px;
}
.safn-img-badges{display:flex;gap:5px;flex-wrap:wrap;align-items:center;}
.safn-ibadge{
  font-size:10px;font-weight:800;color:rgba(255,255,255,0.95);
  background:rgba(0,0,0,0.45);backdrop-filter:blur(8px);
  padding:3px 9px;border-radius:7px;
  border:1px solid rgba(255,255,255,0.25);
  letter-spacing:0.02em;
}
.safn-ibadge-art{
  font-family:'JetBrains Mono',monospace;
  font-size:10px;font-weight:800;
  color:#fff;background:var(--acc);
  padding:3px 9px;border-radius:7px;
  letter-spacing:0.04em;
  border:1px solid rgba(255,255,255,0.25);
}

/* ── No-image preview (label sketch) ── */
.safn-preview-clean{
  padding:14px 14px 12px;background:var(--bg);flex-shrink:0;
  border-bottom:1px solid var(--border);
}
.safn-prev-product{
  font-size:16px;font-weight:900;color:var(--text);line-height:1.2;
  overflow:hidden;white-space:nowrap;text-overflow:ellipsis;
  letter-spacing:-0.01em;margin-bottom:7px;
}
.safn-prev-chips2{display:flex;gap:4px;flex-wrap:wrap;margin-top:5px;}
.safn-prev-barwrap{margin-top:8px;height:14px;overflow:hidden;border-radius:2px;}
.safn-prev-bar2{height:100%;border-radius:2px;}

/* ── Info section ── */
.safn-info-row{padding:10px 13px 8px;display:flex;flex-direction:column;gap:0;flex:1;}

/* Name row — only shown when no image */
.safn-name{font-size:14px;font-weight:800;color:var(--text);line-height:1.2;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.01em;margin-bottom:5px;}

/* Chips */
.safn-chips{display:flex;gap:5px;flex-wrap:wrap;margin-top:5px;}
.safn-chip{
  display:inline-flex;align-items:center;gap:3px;
  font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;
  white-space:nowrap;line-height:1;border:1.5px solid transparent;
}
.sc-green{background:#e6f5db;color:#2a5e1e;border-color:#b8dfa8;}
.sc-blue{background:#e8f1fb;color:#1a5fa5;border-color:#b5d4f4;}
.sc-purple{background:#eeebfc;color:#4a38b0;border-color:#cec9f5;}
.sc-mono{background:var(--s3);color:var(--text2);border-color:var(--border2);font-family:'JetBrains Mono',monospace;font-size:10.5px;}

/* Compact meta + author */
.safn-meta-row{
  display:flex;align-items:center;gap:6px;margin-top:8px;flex-wrap:wrap;
}
.safn-meta-date{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--text3);font-weight:600;}
.safn-meta-dot{color:var(--border2);font-size:10px;}
.safn-av{width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:7px;font-weight:800;flex-shrink:0;letter-spacing:.02em;}
.safn-an{font-size:10px;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px;}
.safn-ver{margin-left:auto;font-size:10px;color:var(--text3);font-weight:600;font-family:'JetBrains Mono',monospace;white-space:nowrap;}

/* Doc tabs */
.safn-doc-tabs{display:flex;gap:4px;margin-top:9px;border-top:1px solid var(--border);padding-top:9px;}
.safn-doc-tab{flex:1;padding:6px 4px;border-radius:8px;border:1.5px solid var(--border);background:var(--s2);color:var(--text2);font-family:'DM Sans',sans-serif;font-size:0.7rem;font-weight:600;cursor:pointer;text-align:center;transition:all 0.15s;white-space:nowrap;}
.safn-doc-tab:hover{transform:translateY(-1px);}
.safn-doc-midi:hover{border-color:var(--acc);color:var(--acc);background:var(--acc-dim);}
.safn-doc-databla:hover{border-color:#1a6fba;color:#1a6fba;background:rgba(26,111,186,0.1);}
.safn-doc-uppskrift:hover{border-color:#7b3fa0;color:#7b3fa0;background:rgba(123,63,160,0.1);}

/* Action row */
.safn-actions{
  display:flex;gap:5px;padding:0 10px 10px;margin-top:auto;
}
.safn-btn-use{
  flex:1;padding:7px 10px;border-radius:8px;
  background:var(--acc);color:#fff;border:none;
  font-size:12px;font-weight:700;cursor:pointer;
  font-family:'DM Sans',sans-serif;letter-spacing:.02em;
  transition:all .15s;display:flex;align-items:center;justify-content:center;gap:4px;
}
.safn-btn-use:hover{background:var(--acc-light);transform:translateY(-1px);}
.safn-btn-use:active{transform:translateY(0);}
.safn-btn-icon{
  width:30px;height:30px;border-radius:8px;
  border:1.5px solid var(--border);background:var(--s2);
  color:var(--text2);font-size:13px;cursor:pointer;
  display:grid;place-items:center;transition:all .15s;flex-shrink:0;
}
.safn-btn-icon:hover{border-color:var(--acc);color:var(--acc);background:var(--acc-dim);}
.safn-btn-del{color:var(--red)!important;}
.safn-btn-del:hover{border-color:var(--red)!important;color:#fff!important;background:var(--red)!important;}

/* Variant badge + list */
.safn-var-badge{font-size:0.68rem;font-weight:700;color:var(--acc);background:var(--acc-dim);padding:2px 7px;border-radius:20px;}
.safn-variants-list{padding:0 12px 10px;display:flex;flex-direction:column;gap:4px;}
.safn-variant-row{display:flex;align-items:center;gap:6px;padding:6px 10px;border-radius:8px;cursor:pointer;background:var(--s2);border:1px solid var(--border2);font-size:0.75rem;transition:background .15s;}
.safn-variant-row:hover{background:var(--acc-dim);border-color:var(--acc);}
.safn-variant-dot{color:var(--text3);font-size:0.8rem;}
.safn-variant-name{flex:1;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.safn-variant-art{font-family:'DM Mono',monospace;font-size:0.68rem;color:var(--text3);background:var(--s3);padding:1px 5px;border-radius:4px;}
.safn-variant-del{margin-left:auto;font-size:0.75rem;opacity:0.4;cursor:pointer;padding:2px 4px;border-radius:4px;transition:opacity .15s;}
.safn-variant-del:hover{opacity:1;color:var(--red);}

/* Empty state */
.safn-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;}

/* MOBILE */
.mob-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:64px;background:var(--s1);border-top:1.5px solid var(--border);padding:6px 12px;gap:4px;z-index:150;padding-bottom:max(6px,env(safe-area-inset-bottom));box-sizing:border-box;}
.mnb{flex:1;padding:8px 4px;border-radius:var(--r);border:none;background:transparent;color:var(--text3);font-family:'DM Sans',sans-serif;font-size:0.68rem;font-weight:600;cursor:pointer;text-align:center;transition:all 0.18s;display:flex;flex-direction:column;align-items:center;gap:3px;}
.mnb .mni{font-size:1.2rem;line-height:1;transition:transform 0.15s;}
.mnb.active{color:var(--acc-bright);}
.mnb.active .mni{filter:drop-shadow(0 0 4px var(--acc));}
/* ════ RESPONSIVE LAYOUT ═══════════════════════════════════════════════════ */

/* Large desktop */
@media(min-width:1300px){
  .app{grid-template-columns:320px 1fr 320px;}
}

/* Standard desktop / fullscreen */
@media(min-width:1100px) and (max-width:1299px){
  .app{grid-template-columns:290px 1fr 285px;}
}

/* Small desktop / iPad landscape / half-screen MacBook */
@media(min-width:960px) and (max-width:1099px){
  .app{grid-template-columns:265px 1fr 255px;}
  .fsec-title{font-size:0.72rem;}
  .fi,.fi-sel{font-size:0.78rem;}
}

/* Half-screen / wide tablet landscape */
@media(min-width:840px) and (max-width:959px){
  :root{--topbar-h:72px;}
  .app{grid-template-columns:240px 1fr 232px;}
  .fsec-title{font-size:0.7rem;padding:11px 14px;}
  .fi,.fi-sel{font-size:0.75rem;padding:7px 8px;}
  .nb{font-size:0.7rem;padding:6px 10px;}
  .ctool{padding:4px 8px;font-size:0.72rem;}
}

/* Narrow half-screen / iPad portrait / small laptop half */
@media(min-width:700px) and (max-width:839px){
  :root{--topbar-h:60px;}
  .app{grid-template-columns:210px 1fr 205px;}
  .fsec-title{font-size:0.68rem;padding:10px 12px;}
  .fi,.fi-sel{font-size:0.72rem;padding:6px 7px;}
  .nb{font-size:0.72rem;padding:6px 10px;}
  .btn{font-size:0.72rem;padding:7px 9px;}
  .seg-btn,.tp-btn{font-size:0.66rem;padding:5px 2px;}
  .lpa-btn{font-size:0.72rem;}
  .topbar{padding:0 10px;gap:8px;}
  .logo-domain{display:none;}
  .ctool{padding:3px 6px;font-size:0.68rem;}
  .ctb-sep{display:none;}
  .tright .chip{font-size:0.62rem;padding:3px 7px;}
}

/* Mobile / phone / portrait small tablet — bottom tab nav */
@media(max-width:699px){
  :root{--topbar-h:54px;}
  .app{grid-template-columns:1fr!important;padding-bottom:64px;}
  .p-left,.p-right{display:none!important;flex-direction:column;}
  .p-left.mob-show{display:flex!important;position:fixed;top:var(--topbar-h);left:0;right:0;bottom:64px;z-index:200;overflow:hidden;}
  .p-right.mob-show{display:flex!important;position:fixed;top:var(--topbar-h);left:0;right:0;bottom:64px;z-index:200;overflow:hidden;}
  .mob-nav{display:flex;}
  .topbar{padding:0 10px;gap:6px;}
  .logo-domain{display:none;}
  .canvas-wrap{padding:10px 6px;}
  .nb{display:none;}
  .tsep{display:none;}
  .tcenter{display:none;}
  .tright .chip{display:none;}
  .ctb-bar{padding:4px 6px;gap:2px;}
  .ctool{padding:4px 7px;font-size:0.72rem;}
  .ctb-sep{display:none;}
}

/* Very small phones */
@media(max-width:400px){
  :root{--topbar-h:50px;}
  .canvas-wrap{padding:6px 2px;}
  .topbar{padding:0 6px;gap:4px;}
  .logo-name{font-size:1.1rem!important;}
}

/* NOTIF */

/* ─── CANVAS EXTRAS (grid, rulers, crosshair) ───────────────── */
.cgrid{position:absolute;inset:0;pointer-events:none;z-index:0;display:none;opacity:0.5;background-image:linear-gradient(rgba(0,0,0,0.07) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,0.07) 1px,transparent 1px);background-size:20px 20px;}
.cgrid.show{display:block;}
.ruler-h{position:absolute;top:0;left:22px;right:0;height:22px;background:var(--s1);border-bottom:1px solid var(--border);z-index:6;display:none;overflow:hidden;pointer-events:none;}
.ruler-v{position:absolute;top:22px;left:0;bottom:24px;width:22px;background:var(--s1);border-right:1px solid var(--border);z-index:6;display:none;overflow:hidden;pointer-events:none;}
.ruler-corner{position:absolute;top:0;left:0;width:22px;height:22px;background:var(--s1);border-right:1px solid var(--border);border-bottom:1px solid var(--border);z-index:7;display:none;}
.ruler-active .ruler-h,.ruler-active .ruler-v,.ruler-active .ruler-corner{display:block;}
.crosshair-h{position:absolute;left:0;right:0;height:1px;background:rgba(42,94,30,0.25);pointer-events:none;z-index:15;display:none;}
.crosshair-v{position:absolute;top:0;bottom:0;width:1px;background:rgba(42,94,30,0.25);pointer-events:none;z-index:15;display:none;}
.crosshair-on .crosshair-h,.crosshair-on .crosshair-v{display:block;}

/* ─── EMPTY STATE ────────────────────────────────────────────── */
#es-overlay{position:absolute;inset:0;z-index:20;background:rgba(198,192,183,0.72);backdrop-filter:blur(18px) saturate(1.2);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity 0.4s ease;}
[data-theme="dark"] #es-overlay{background:rgba(10,14,9,0.78);}
#es-overlay.es-show{opacity:1;pointer-events:auto;}
#es-overlay.es-show~.canvas-center{visibility:hidden;}

/* Floating label cards */
.es-lbl{position:absolute;border-radius:5px;background:rgba(255,255,255,0.22);border:1.5px solid rgba(255,255,255,0.5);box-shadow:0 4px 20px rgba(0,0,0,0.08);animation:esFloat ease-in-out infinite alternate;overflow:hidden;}
.es-lbl::before{content:'';position:absolute;top:14%;left:12%;right:12%;height:2.5px;border-radius:2px;background:rgba(255,255,255,0.6);box-shadow:0 7px 0 rgba(255,255,255,0.35),0 14px 0 rgba(255,255,255,0.2),0 21px 0 rgba(255,255,255,0.28);}
.es-lbl::after{content:'';position:absolute;bottom:12%;left:12%;right:12%;height:11%;background:repeating-linear-gradient(90deg,rgba(255,255,255,0.5) 0,rgba(255,255,255,0.5) 2px,transparent 2px,transparent 4.5px,rgba(255,255,255,0.3) 4.5px,rgba(255,255,255,0.3) 5.5px,transparent 5.5px,transparent 8px);border-radius:1px;}
.es-lbl.es-solid{background:rgba(255,255,255,0.38);border-color:rgba(255,255,255,0.75);box-shadow:0 8px 32px rgba(0,0,0,0.12);}
@keyframes esFloat{0%{transform:translateY(0) rotate(var(--r,0deg));}100%{transform:translateY(-14px) rotate(var(--r,0deg));}}

/* Card */
#es-card{position:relative;z-index:2;background:rgba(255,255,255,0.97);border-radius:24px;border:1px solid rgba(255,255,255,1);box-shadow:0 24px 80px rgba(0,0,0,0.16),0 8px 32px rgba(0,0,0,0.08);padding:40px 44px 38px;text-align:center;max-width:320px;width:90%;animation:esCardIn 0.45s cubic-bezier(0.34,1.2,0.64,1) forwards;}
@keyframes esCardIn{0%{opacity:0;transform:translateY(16px) scale(0.96);}100%{opacity:1;transform:translateY(0) scale(1);}}
[data-theme="dark"] #es-card{background:rgba(22,28,20,0.97);border-color:rgba(255,255,255,0.07);box-shadow:0 24px 80px rgba(0,0,0,0.55);}
#es-logo-icon{width:62px;height:62px;border-radius:16px;background:linear-gradient(135deg,#2a5e1e 0%,#3d7a28 100%);margin:0 auto 22px;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 28px rgba(42,94,30,0.40);}
#es-title{font-size:1.35rem;font-weight:800;color:var(--text);letter-spacing:-0.6px;margin-bottom:4px;font-family:'DM Sans',sans-serif;}
#es-tagline{font-size:0.7rem;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;color:var(--acc);margin-bottom:12px;opacity:0.9;}
#es-sub{font-size:0.81rem;color:var(--text2);line-height:1.62;margin-bottom:30px;}
.es-actions{display:flex;flex-direction:column;gap:10px;}
.es-btn-primary{padding:14px 0;background:var(--acc);color:#fff;border:none;border-radius:13px;font-size:0.9rem;font-weight:700;cursor:pointer;font-family:'DM Sans',sans-serif;box-shadow:0 4px 16px rgba(42,94,30,0.30);transition:background 0.15s,transform 0.12s,box-shadow 0.15s;letter-spacing:0.01em;}
.es-btn-primary:hover{background:var(--acc-light);transform:translateY(-2px);box-shadow:0 8px 24px rgba(42,94,30,0.40);}
.es-btn-secondary{padding:13px 0;background:transparent;color:var(--text2);border:1.5px solid var(--border2);border-radius:13px;font-size:0.85rem;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif;transition:border-color 0.15s,color 0.15s,transform 0.12s;}
.es-btn-secondary:hover{border-color:var(--acc);color:var(--acc);transform:translateY(-1px);}
.notif{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(80px);background:var(--acc);color:#fff;padding:12px 24px;border-radius:24px;font-size:0.84rem;font-weight:700;z-index:9999;opacity:0;transition:all 0.3s cubic-bezier(0.34,1.56,0.64,1);white-space:nowrap;box-shadow:0 8px 24px rgba(45,106,34,0.3);pointer-events:none;}
.notif.show{transform:translateX(-50%) translateY(0);opacity:1;}

/* LOADING */
.loading{position:fixed;inset:0;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:2000;gap:16px;background-image:radial-gradient(ellipse 60% 40% at 50% 50%,rgba(45,106,34,0.06) 0%,transparent 70%);}
.loading-logo{font-family:'Bebas Neue',sans-serif;font-size:2.2rem;letter-spacing:0.08em;}
.loading-logo span{color:var(--acc-light);}
.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--acc);border-radius:50%;animation:spin 0.8s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}

/* PRINT */
@media print{
  /* Hide EVERYTHING except the print overlay */
  body > *{display:none!important;}
  /* Show only the print overlay */
  #__printOverlay{
    display:block!important;
    position:fixed!important;
    top:0!important;left:0!important;right:0!important;bottom:0!important;
    margin:0!important;padding:0!important;
    background:white!important;
    z-index:999999!important;
  }
  #__printOverlay img{
    display:block!important;
    margin:0 auto!important;
    -webkit-print-color-adjust:exact!important;
    print-color-adjust:exact!important;
    color-adjust:exact!important;
  }
  @page{margin:0;padding:0;size:auto;}
}




















/* ── RBAR: save/update bar at top of right panel ── */
.rbar{padding:10px 12px;background:linear-gradient(135deg,var(--s1) 0%,var(--s2) 100%);border-bottom:1.5px solid var(--border);flex-shrink:0;}
.rb-btn{
  display:block;width:100%;padding:11px 8px;
  border:none;border-radius:var(--r);
  font-family:'DM Sans',sans-serif;font-size:0.84rem;font-weight:700;
  cursor:pointer;text-align:center;box-sizing:border-box;
  transition:all 0.18s cubic-bezier(0.34,1.2,0.64,1);
  letter-spacing:0.02em;
}
.rb-save{
  background:var(--acc);color:#fff;
  box-shadow:0 2px 8px rgba(42,94,30,0.3);
}
.rb-save:hover{
  background:var(--acc-light);
  transform:translateY(-1px);
  box-shadow:0 5px 14px rgba(42,94,30,0.38);
}
.rb-save:active{transform:translateY(0);}

/* ── LEFT PANEL TOP ACTION BAR ── */
/* OLD lpa-btn rules — replaced by lp-btn-primary/secondary/ghost */
.lpa-btn,.lpa-new,.lpa-print{display:none!important;}

/* ── PANEL HEADER ── */
.ph{
  padding:13px 18px;
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  flex-shrink:0;background:var(--s1);
  position:sticky;top:0;z-index:10;
}
.ph-title{
  font-size:0.68rem;font-weight:800;letter-spacing:0.12em;
  text-transform:uppercase;color:var(--acc);
  display:flex;align-items:center;gap:6px;
}

/* ── CANVAS TOOLBAR ── */
.ctb-bar{
  padding:5px 10px;border-bottom:1.5px solid var(--border);
  display:flex;align-items:center;gap:2px;
  flex-shrink:0;background:var(--s1);
  overflow-x:auto;overflow-y:hidden;
  position:relative;z-index:5;
  -webkit-overflow-scrolling:touch;white-space:nowrap;
}
.ctb-bar::-webkit-scrollbar{height:2px;}
.ctb-bar::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px;}
.ctool{
  padding:6px 10px;border-radius:6px;border:none;
  background:transparent;color:var(--text2);
  font-family:'DM Sans',sans-serif;font-size:0.74rem;font-weight:500;
  cursor:pointer;transition:all 0.15s;white-space:nowrap;
  display:flex;align-items:center;gap:4px;
}
.ctool:hover{background:var(--s3);color:var(--text);}
.ctool.act,.ctool.active-green{background:var(--acc-dim);color:var(--acc);font-weight:700;}
.ctb-group{display:flex;gap:2px;}
.ctb-sep{width:1px;height:20px;background:var(--border);margin:0 5px;flex-shrink:0;align-self:center;}

/* ── CANVAS HEADER ── */
.canvas-header{
  height:46px;padding:0 16px;
  border-bottom:1.5px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  flex-shrink:0;background:linear-gradient(135deg,var(--s1) 0%,var(--s2) 100%);position:relative;z-index:5;
}

/* ── CANVAS WRAP ── */
.canvas-wrap{
  flex:1;display:flex;align-items:center;justify-content:center;
  padding:32px 28px;overflow:auto;position:relative;
  background:
    radial-gradient(ellipse 70% 60% at 50% 40%,rgba(42,94,30,0.08) 0%,transparent 70%),
    repeating-linear-gradient(0deg,transparent,transparent 20px,rgba(0,0,0,0.02) 20px,rgba(0,0,0,0.02) 21px),
    repeating-linear-gradient(90deg,transparent,transparent 20px,rgba(0,0,0,0.02) 20px,rgba(0,0,0,0.02) 21px);
  background-color:#cdc7bb;
}
.canvas-center{display:inline-flex;align-items:center;justify-content:center;min-width:100%;min-height:100%;}
/* Label stage gets subtle shadow for depth */
.stage{
  box-shadow:
    0 1px 2px rgba(0,0,0,0.08),
    0 4px 12px rgba(0,0,0,0.10),
    0 16px 40px rgba(0,0,0,0.14),
    0 24px 64px rgba(0,0,0,0.08),
    0 0 0 1px rgba(0,0,0,0.05);
  border-radius:2px;
  transition:box-shadow 0.3s ease;
}
.stage:hover{
  box-shadow:
    0 2px 4px rgba(0,0,0,0.09),
    0 6px 16px rgba(0,0,0,0.11),
    0 20px 48px rgba(0,0,0,0.15),
    0 28px 72px rgba(0,0,0,0.09),
    0 0 0 1px rgba(0,0,0,0.06);
}
[data-theme="dark"] .stage{
  box-shadow:
    0 1px 2px rgba(0,0,0,0.3),
    0 8px 24px rgba(0,0,0,0.4),
    0 20px 60px rgba(0,0,0,0.35),
    0 0 0 1px rgba(255,255,255,0.05);
}


/* ─── ZOOM MENU ─────────────────────────────────────────────── */
.zoom-menu{position:absolute;top:calc(100% + 4px);left:50%;transform:translateX(-50%);background:var(--s1);border:1px solid var(--border2);border-radius:10px;box-shadow:0 8px 28px rgba(0,0,0,0.14);z-index:200;min-width:80px;padding:4px;display:none;}
.zoom-menu.open{display:block;}
.zoom-menu-item{padding:6px 14px;font-size:0.76rem;color:var(--text2);cursor:pointer;border-radius:6px;text-align:center;}
.zoom-menu-item:hover{background:var(--s3);color:var(--text);}
.zoom-menu-item.cur{color:var(--acc);font-weight:700;}

/* ─── PAN MODE ───────────────────────────────────────────────── */
.pan-mode #cwrap{cursor:grab;}
.pan-mode #cwrap.panning{cursor:grabbing;}
#ccenter{transition:none;will-change:transform;}

/* ─── SNAP GUIDES ────────────────────────────────────────────── */
.sg-line{position:absolute;pointer-events:none;z-index:22;}
.sg-h{left:0;right:0;height:1px;background:rgba(79,158,255,0.8);box-shadow:0 0 3px rgba(79,158,255,0.4);}
.sg-v{top:0;bottom:0;width:1px;background:rgba(79,158,255,0.8);box-shadow:0 0 3px rgba(79,158,255,0.4);}
.sg-label{position:absolute;font-size:9px;font-family:monospace;color:#4f9eff;background:rgba(0,0,0,0.55);padding:1px 4px;border-radius:2px;white-space:nowrap;}

/* ─── CANVAS WARM PAPER SURFACE ─────────────────────────────── */
.canvas-wrap{
  flex:1;display:flex;align-items:center;justify-content:center;
  padding:32px 28px;overflow:hidden;position:relative;
  background-color:#d6cfbf;
  background-image:
    radial-gradient(ellipse 85% 70% at 50% 42%,rgba(42,94,30,0.055) 0%,transparent 72%),
    repeating-linear-gradient(45deg,transparent 0,transparent 2px,rgba(60,40,20,0.018) 2px,rgba(60,40,20,0.018) 3px),
    repeating-linear-gradient(-45deg,transparent 0,transparent 2px,rgba(60,40,20,0.018) 2px,rgba(60,40,20,0.018) 3px);
}
.canvas-wrap::before{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:radial-gradient(circle,rgba(60,40,20,0.05) 1px,transparent 1.4px);
  background-size:22px 22px;
  opacity:0.45;
}
.canvas-wrap::after{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:0;
  background:radial-gradient(ellipse 100% 80% at 50% 50%,transparent 40%,rgba(0,0,0,0.08) 100%);
}
.canvas-center{position:relative;z-index:1;display:inline-flex;align-items:center;justify-content:center;min-width:100%;min-height:100%;}
[data-theme="dark"] .canvas-wrap{background-color:#1c1c1c;background-image:none;}
[data-theme="dark"] .canvas-wrap::before{opacity:0.15;background-image:radial-gradient(circle,rgba(255,255,255,0.12) 1px,transparent 1.4px);}
[data-theme="dark"] .canvas-wrap::after{background:radial-gradient(ellipse 100% 80% at 50% 50%,transparent 40%,rgba(0,0,0,0.4) 100%);}

/* ─── STAGE ENTRANCE (opacity only — NOT transform) ─────────── */
@keyframes stageEntrance{0%{opacity:0;}100%{opacity:1;}}
.stage.entrance{animation:stageEntrance 0.3s ease forwards;}

/* ─── ICON TOOLBAR (.ti) ─────────────────────────────────────── */
.tb-group{display:flex;align-items:center;gap:1px;}
.tb-group+.tb-group{border-left:1px solid var(--border);margin-left:3px;padding-left:3px;}
.ti{width:30px;height:30px;border-radius:7px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background 0.1s;position:relative;flex-shrink:0;padding:0;color:var(--text2);}
.ti:hover{background:var(--s3);color:var(--text);}
.ti.act{background:var(--acc-dim);color:var(--acc);}
.ti svg{width:15px;height:15px;pointer-events:none;}
.ti-tip{position:absolute;bottom:-28px;left:50%;transform:translateX(-50%);background:rgba(20,20,20,0.9);color:#fff;font-size:10px;padding:3px 7px;border-radius:5px;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity 0.15s;z-index:100;}
.ti:hover .ti-tip{opacity:1;}
[data-theme="dark"] .ti:hover{background:rgba(255,255,255,0.07);}

/* ─── CTOOL (backwards compat) ───────────────────────────────── */
.ctool{padding:5px 9px;border-radius:6px;border:none;background:transparent;color:var(--text2);font-family:'DM Sans',sans-serif;font-size:0.73rem;font-weight:500;cursor:pointer;transition:all 0.12s;white-space:nowrap;display:flex;align-items:center;gap:4px;}
.ctool:hover{background:var(--s3);color:var(--text);}
.ctool.act{background:var(--acc-dim);color:var(--acc);font-weight:700;}

/* ─── CANVAS HEADER LIGHT ────────────────────────────────────── */
.canvas-header{height:44px;padding:0 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;background:var(--s1);position:relative;z-index:5;}
.canvas-header .ph-title{color:var(--text2);font-size:0.78rem;font-weight:500;}
.ctb-bar{padding:4px 8px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:0;flex-shrink:0;background:var(--s1);overflow-x:auto;overflow-y:hidden;position:relative;z-index:5;-webkit-overflow-scrolling:touch;white-space:nowrap;}
.ctb-bar::-webkit-scrollbar{height:2px;}
.ctb-bar::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px;}
.ctb-sep{width:1px;height:18px;background:var(--border);margin:0 3px;flex-shrink:0;align-self:center;}

/* ─── STATUS BAR ─────────────────────────────────────────────── */
.canvas-statusbar{height:22px;border-top:1px solid var(--border);display:flex;align-items:center;padding:0 12px;gap:14px;background:var(--s1);flex-shrink:0;font-family:'JetBrains Mono',monospace;font-size:0.65rem;color:var(--text3);}
.sb-item b{color:var(--text2);}
.sb-spacer{flex:1;}
[data-theme="dark"] .canvas-header,[data-theme="dark"] .ctb-bar,[data-theme="dark"] .canvas-statusbar{background:#111;border-color:rgba(255,255,255,0.07);}

/* ─── GORGEOUS ACCORDION ─────────────────────────────────────── */
.fsec{border-radius:0;border:none;border-bottom:1px solid var(--border);margin:0;background:transparent;overflow:hidden;transition:background 0.12s;}
.fsec:last-child{border-bottom:none;}
.fsec:hover{background:rgba(42,94,30,0.018);}
.fsec.open>.fsec-title{color:var(--acc);}
.fsec.open>.fsec-title .fsec-title-icon{background:var(--acc-dim);}
.fsec-title{display:flex;align-items:center;justify-content:space-between;padding:11px 16px;cursor:pointer;font-size:0.74rem;font-weight:700;color:var(--text);letter-spacing:0.005em;user-select:none;transition:color 0.12s;}
.fsec-title:hover{color:var(--acc);}
.fsec-title-icon{font-size:13px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:7px;background:var(--s3);transition:transform 0.18s cubic-bezier(0.34,1.4,0.64,1),background 0.15s;}
.fsec:hover .fsec-title-icon{transform:scale(1.1);}
/* Chevron arrow */
.fsec-arrow{font-size:10px;color:var(--text3);transition:transform 0.2s cubic-bezier(0.4,0,0.2,1),color 0.12s;margin-left:auto;padding-left:8px;flex-shrink:0;}
.fsec.open>.fsec-title .fsec-arrow{transform:rotate(90deg);color:var(--acc);}
.fsec-inner{padding:0 16px 14px;}

/* ─── LEFT PANEL ACTIONS — see lp-btn-primary/secondary/ghost ── */

/* ─── SCROLL ─────────────────────────────────────────────────── */
.scroll{flex:1;overflow-y:auto;overflow-x:hidden;scroll-behavior:smooth;}
.scroll::-webkit-scrollbar{width:4px;}
.scroll::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px;}
.scroll::-webkit-scrollbar-thumb:hover{background:var(--acc);}

/* ─── BRAND SWATCHES ─────────────────────────────────────────── */
#swatches-panel{position:absolute;top:calc(100% + 6px);left:0;background:var(--s1);border:1px solid var(--border2);border-radius:10px;box-shadow:0 8px 28px rgba(0,0,0,0.15);z-index:200;padding:12px;width:220px;display:none;}
#swatches-panel.open{display:block;}
.swatch-title{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);margin-bottom:8px;}
.swatch-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:5px;margin-bottom:10px;}
.swatch{width:28px;height:28px;border-radius:6px;cursor:pointer;border:2px solid transparent;transition:transform 0.1s,border-color 0.1s;}
.swatch:hover{transform:scale(1.15);border-color:var(--border2);}
.swatch-add-row{display:flex;gap:6px;align-items:center;}
.swatch-add-row input[type=color]{width:28px;height:28px;border:none;border-radius:6px;padding:0;cursor:pointer;}
.swatch-add-row button{flex:1;padding:5px;border:1px solid var(--border2);border-radius:6px;background:transparent;font-size:11px;cursor:pointer;color:var(--text2);}
.swatch-add-row button:hover{background:var(--s2);}

/* ─── IMAGE CROP HANDLES ─────────────────────────────────────── */
.crop-handle{position:absolute;width:10px;height:10px;background:var(--acc);border:2px solid #fff;border-radius:2px;z-index:15;cursor:nwse-resize;box-shadow:0 1px 4px rgba(0,0,0,0.3);}
.crop-toolbar{position:absolute;top:-34px;left:50%;transform:translateX(-50%);background:rgba(20,20,20,0.92);border-radius:8px;padding:4px 8px;display:flex;gap:6px;white-space:nowrap;z-index:16;pointer-events:auto;}
.crop-tb-btn{background:none;border:none;color:#fff;cursor:pointer;font-size:11px;padding:3px 6px;border-radius:4px;}
.crop-tb-btn:hover{background:rgba(255,255,255,0.15);}
.limg-crop-active{outline:2px solid var(--acc) !important;}

/* ─── IMPROVED NOTIFICATION ──────────────────────────────────── */
.notif{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(80px);background:var(--s1);color:var(--text);padding:11px 20px;border-radius:24px;font-size:0.82rem;font-weight:600;z-index:9999;opacity:0;transition:all 0.35s cubic-bezier(0.34,1.3,0.64,1);white-space:nowrap;box-shadow:0 8px 28px rgba(0,0,0,0.16),0 2px 8px rgba(0,0,0,0.08);pointer-events:none;border:1px solid var(--border2);}
.notif.show{transform:translateX(-50%) translateY(0);opacity:1;}
.notif.err{background:var(--red);color:#fff;border:none;}
.notif.info{background:var(--blue);color:#fff;border:none;}
.notif.acc{background:var(--acc);color:#fff;border:none;}
[data-theme="dark"] .notif{background:#232323;border-color:rgba(255,255,255,0.1);}
/* ── NOTIFICATION ── */
.notif{
  position:fixed;bottom:28px;left:50%;
  transform:translateX(-50%) translateY(80px);
  background:var(--acc);color:#fff;
  padding:12px 24px;border-radius:28px;
  font-size:0.84rem;font-weight:700;z-index:9999;
  opacity:0;
  transition:all 0.32s cubic-bezier(0.34,1.56,0.64,1);
  white-space:nowrap;
  box-shadow:0 8px 28px rgba(42,94,30,0.35),0 2px 8px rgba(0,0,0,0.15);
  pointer-events:none;
  display:flex;align-items:center;gap:8px;
}
.notif.show{transform:translateX(-50%) translateY(0);opacity:1;}
.notif.err{background:var(--red);box-shadow:0 8px 28px rgba(192,57,43,0.35);}
.notif.info{background:var(--blue);box-shadow:0 8px 28px rgba(26,111,186,0.35);}

/* ── LOADING SCREEN ── */
.loading{
  position:fixed;inset:0;background:var(--bg);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  z-index:2000;gap:18px;
  background-image:radial-gradient(ellipse 60% 40% at 50% 50%,rgba(45,106,34,0.06) 0%,transparent 70%);
}
.loading-logo{font-family:'Bebas Neue',sans-serif;font-size:2.4rem;letter-spacing:0.1em;color:var(--text);}
.loading-logo span{color:var(--acc-light);}
.spinner{
  width:32px;height:32px;
  border:2.5px solid var(--border2);
  border-top-color:var(--acc);border-radius:50%;
  animation:spin 0.75s linear infinite;
}

/* ── SCROLLBAR refinements ── */
.scroll::-webkit-scrollbar{width:3px;}
.scroll::-webkit-scrollbar-track{background:transparent;}
.scroll::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px;}
.scroll::-webkit-scrollbar-thumb:hover{background:var(--acc);}

/* ── SMALL BUTTON in panel headers ── */
.adj-btn{
  width:28px;height:28px;border-radius:7px;
  border:1.5px solid var(--border);background:var(--s2);
  color:var(--text);font-size:0.9rem;cursor:pointer;
  display:grid;place-items:center;flex-shrink:0;
  transition:all 0.15s;font-weight:700;line-height:1;
}
.adj-btn:hover{border-color:var(--acc);color:var(--acc);background:var(--acc-dim);}

/* ── FONT SELECTOR ── */
.font-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:4px;}
.font-opt{
  padding:10px 10px;border-radius:8px;
  border:1.5px solid var(--border);background:var(--s2);
  cursor:pointer;font-size:0.98rem;text-align:center;letter-spacing:0.01em;
  transition:all 0.18s cubic-bezier(0.34,1.2,0.64,1);
  white-space:nowrap;color:var(--text);
  position:relative;
}
.font-opt.sel{
  border-color:var(--acc);background:var(--acc-dim);color:var(--acc);
  font-weight:700;
  box-shadow:0 2px 8px rgba(42,94,30,0.18),inset 0 1px 0 rgba(255,255,255,0.4);
  transform:translateY(-1px);
}
.font-opt:hover{
  border-color:var(--acc-light);background:var(--s3);
  transform:translateY(-1px);
  box-shadow:0 2px 6px rgba(0,0,0,0.06);
}
.font-opt:active{transform:translateY(0);}

/* ── STAT BOX ── */
.stat-box{
  background:var(--s1);border:1.5px solid var(--border);
  border-radius:var(--r2);padding:10px 14px;min-width:90px;
  box-shadow:var(--shadow);
}
.stat-box .sv{font-family:'Bebas Neue',sans-serif;font-size:1.6rem;color:var(--acc);line-height:1;letter-spacing:0.04em;}
.stat-box .sl{font-size:0.64rem;font-weight:700;text-transform:uppercase;letter-spacing:0.09em;color:var(--text3);margin-top:2px;}

/* ── WOW FACTOR CSS ── */
@keyframes modalSlideIn{
  0%{opacity:0;transform:translateY(24px) scale(0.97);}
  60%{opacity:1;}
  100%{opacity:1;transform:translateY(0) scale(1);}
}
.btn:active,.lpa-btn:active,.rb-btn:active{
  transform:scale(0.95)!important;
  transition:transform 0.08s ease!important;
}
.lpa-btn-print-hover-gone{display:none;}
@keyframes fieldFlash{
  0%{background:rgba(42,94,30,0.15);}
  100%{background:transparent;}
}
.fi:focus{
  outline:none;border-color:var(--acc);
  box-shadow:0 0 0 3px var(--acc-dim);
  transition:border-color 0.2s,box-shadow 0.2s,background 0.2s;
}
#stage{transition:transform 0.2s cubic-bezier(0.34,1.2,0.64,1);}
#mod-print-preview .modal{
  max-width:480px;
  background:linear-gradient(145deg,var(--s1) 0%,var(--s2) 100%);
  border:1px solid rgba(42,94,30,0.2);
  box-shadow:0 24px 64px rgba(0,0,0,0.2);
}
.print-preview-img{
  border-radius:8px;box-shadow:0 8px 32px rgba(0,0,0,0.25);
  display:block;margin:0 auto;max-width:100%;
}
.topbar.scrolled{
  background:rgba(245,241,234,0.96);
  box-shadow:0 1px 0 rgba(255,255,255,0.6) inset, 0 4px 28px rgba(42,94,30,0.12);
}
/* Premium print CTA button in header */
.topbar-print-btn{
  padding:8px 16px;border:none;border-radius:9px;
  background:var(--acc);color:#fff;
  font-family:'DM Sans',sans-serif;font-size:0.82rem;font-weight:700;
  cursor:pointer;
  display:flex;align-items:center;gap:6px;
  box-shadow:0 2px 8px rgba(42,94,30,0.32),0 1px 2px rgba(0,0,0,0.08);
  transition:all 0.18s cubic-bezier(0.34,1.2,0.64,1);
  letter-spacing:0.01em;white-space:nowrap;flex-shrink:0;
}
.topbar-print-btn:hover{
  background:var(--acc-light);
  transform:translateY(-1.5px);
  box-shadow:0 5px 16px rgba(42,94,30,0.38),0 2px 6px rgba(0,0,0,0.1);
}
.topbar-print-btn:active{transform:translateY(0);box-shadow:0 1px 4px rgba(42,94,30,0.3);}
/* Bell button */
.appr-bell{
  position:relative;width:36px;height:36px;border-radius:9px;
  border:1.5px solid var(--border);background:var(--s2);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:1rem;
  transition:all 0.15s;
}
.appr-bell:hover{border-color:var(--acc);background:var(--acc-dim);transform:translateY(-1px);}
.appr-bell-badge{
  position:absolute;top:-5px;right:-5px;
  min-width:17px;height:17px;
  background:var(--red);color:#fff;
  font-size:0.58rem;font-weight:800;
  border-radius:9px;display:flex;align-items:center;justify-content:center;
  padding:0 4px;
  border:2px solid var(--s1);
  font-family:'DM Sans',sans-serif;
}
.stage-text{transition:color 0.2s,font-size 0.2s,font-family 0.2s;}

/* ═══ APPROVAL COMPONENTS ══════════════════════════════════ */
.appr-bell{position:relative;width:36px;height:36px;border-radius:50%;border:1.5px solid var(--border);background:var(--s2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:all 0.2s;flex-shrink:0;}
.appr-bell:hover{border-color:var(--acc);background:var(--acc-dim);}
.appr-bell-badge{position:absolute;top:-4px;right:-4px;min-width:16px;height:16px;border-radius:10px;background:#e74c3c;color:#fff;font-size:9px;font-weight:800;display:flex;align-items:center;justify-content:center;padding:0 3px;border:1.5px solid var(--s1);display:none;}
.appr-status-bar{padding:7px 12px;border-radius:8px;font-size:0.7rem;font-weight:700;display:flex;align-items:center;gap:7px;margin-top:8px;}
.appr-status-bar.pending{background:rgba(255,193,7,0.15);color:#b8860b;border:1px solid rgba(255,193,7,0.4);}
.appr-status-bar.approved{background:rgba(39,174,96,0.13);color:#1a7a40;border:1px solid rgba(39,174,96,0.35);}
.appr-status-bar.rejected{background:rgba(231,76,60,0.12);color:#a93226;border:1px solid rgba(231,76,60,0.35);}
.appr-row{display:flex;align-items:center;gap:10px;padding:11px 14px;border-radius:10px;border:1.5px solid var(--border);margin-bottom:8px;cursor:pointer;transition:all 0.15s;}
.appr-row:hover{border-color:var(--acc);background:var(--acc-dim);}
.appr-row.selected{border-color:var(--acc);background:var(--acc-dim);}
.appr-av{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:0.8rem;font-weight:800;flex-shrink:0;}
.appr-info{flex:1;min-width:0;}
.appr-nm{font-size:0.78rem;font-weight:700;color:var(--text);}
.appr-role{font-size:0.68rem;color:var(--text3);}
.appr-check{font-size:1.1rem;flex-shrink:0;color:var(--acc);}
.stamp-block{border-left:4px solid #27ae60;padding:9px 14px;margin-bottom:8px;background:rgba(39,174,96,0.07);border-radius:0 8px 8px 0;}
.stamp-block.rejected{border-left-color:#e74c3c;background:rgba(231,76,60,0.06);}
.stamp-block.pending{border-left-color:#f39c12;background:rgba(243,156,18,0.07);}
.stamp-label{font-size:0.65rem;font-weight:800;letter-spacing:0.1em;text-transform:uppercase;margin-bottom:4px;}
.stamp-who{font-size:0.8rem;font-weight:700;color:var(--text);}
.stamp-when{font-size:0.7rem;color:var(--text3);margin-top:2px;}
.inbox-item{padding:14px;border:1.5px solid var(--border);border-radius:12px;margin-bottom:10px;cursor:pointer;transition:all 0.15s;}
.inbox-item:hover{border-color:var(--acc);background:var(--acc-dim);}
.inbox-prod{font-size:0.82rem;font-weight:700;color:var(--text);}
.inbox-meta{font-size:0.7rem;color:var(--text3);margin-top:3px;}
.inbox-req{font-size:0.72rem;color:var(--text2);margin-top:6px;font-style:italic;}

/* ═══════════════════════════════════════════════════════════
   ██  SMART AUTOCOMPLETE — Merkið.is  ██
   ═══════════════════════════════════════════════════════════ */
.mac-wrap{position:relative;display:contents;}
.mac-dropdown{
  position:absolute;
  left:0;right:0;top:calc(100% + 4px);
  background:var(--s1);
  border:1.5px solid var(--acc);
  border-radius:10px;
  box-shadow:0 8px 28px rgba(0,0,0,0.16),0 2px 8px rgba(0,0,0,0.08);
  z-index:99999;
  overflow:hidden;
  animation:macSlideIn 0.12s cubic-bezier(0.34,1.2,0.64,1);
  min-width:180px;
  max-height:220px;
  overflow-y:auto;
}
.mac-dropdown::-webkit-scrollbar{width:3px;}
.mac-dropdown::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px;}
@keyframes macSlideIn{
  from{opacity:0;transform:translateY(-6px);}
  to{opacity:1;transform:translateY(0);}
}
.mac-item{
  display:flex;align-items:center;gap:8px;
  padding:9px 12px;
  cursor:pointer;
  font-family:'DM Sans',sans-serif;font-size:0.8rem;
  color:var(--text);
  transition:background 0.1s;
  position:relative;
  border-bottom:0.5px solid var(--border);
}
.mac-item:last-child{border-bottom:none;}
.mac-item:hover,.mac-item.mac-sel{
  background:var(--acc-dim);
  color:var(--acc);
}
.mac-item-icon{
  font-size:0.7rem;color:var(--text3);
  flex-shrink:0;
}
.mac-item.mac-sel .mac-item-icon{color:var(--acc);}
.mac-item-text{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.mac-item-match{font-weight:800;color:var(--acc);}
.mac-item-count{font-size:0.62rem;color:var(--text3);font-family:'JetBrains Mono',monospace;flex-shrink:0;}
.mac-header{
  padding:5px 12px;font-size:0.58rem;font-weight:800;
  letter-spacing:0.12em;text-transform:uppercase;
  color:var(--text3);background:var(--s2);
  border-bottom:0.5px solid var(--border);
}
[data-theme="dark"] .mac-dropdown{background:#1a1a1a;border-color:rgba(42,94,30,0.5);box-shadow:0 8px 28px rgba(0,0,0,0.45);}
[data-theme="dark"] .mac-item:hover,[data-theme="dark"] .mac-item.mac-sel{background:rgba(42,94,30,0.15);}

/* ═══════════════════════════════════════════════════════════
   LEFT PANEL TOP — CLEAN REDESIGN
   ═══════════════════════════════════════════════════════════ */

/* Sticky container */
.lp-top{
  flex-shrink:0;
  background:var(--s1);
  position:sticky;top:0;z-index:10;
  border-bottom:1.5px solid var(--border);
}

/* Brand / title row */
.lp-brand{
  display:flex;align-items:center;justify-content:space-between;
  padding:9px 14px 8px;
  background:linear-gradient(135deg,rgba(42,94,30,0.05) 0%,transparent 80%);
  border-bottom:1px solid var(--border);
}
.lp-brand-left{display:flex;align-items:center;gap:7px;}
.lp-brand-icon{
  width:24px;height:24px;border-radius:7px;
  background:var(--acc-dim);border:1px solid rgba(42,94,30,0.2);
  display:flex;align-items:center;justify-content:center;
  color:var(--acc);flex-shrink:0;
}
.lp-brand-label{
  font-size:0.68rem;font-weight:800;
  letter-spacing:0.08em;text-transform:uppercase;
  color:var(--text2);
}

/* Live status pill */
.lp-live-pill{
  display:flex;align-items:center;gap:4px;
  font-size:0.6rem;font-weight:600;
  color:var(--text3);font-family:'DM Sans',sans-serif;
  padding:2px 7px;border-radius:20px;
  border:1px solid var(--border);
  background:var(--s2);
  transition:all 0.3s;
  max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.lp-live-dot{
  width:5px;height:5px;border-radius:50%;
  background:var(--border2);flex-shrink:0;
  transition:background 0.3s,box-shadow 0.3s;
}
.lp-live-dot.live{
  background:#27ae60;
  box-shadow:0 0 0 2px rgba(39,174,96,0.25);
}

/* Action buttons row */
.lp-actions{
  display:flex;align-items:center;gap:7px;
  padding:10px 12px;
}

/* Primary — Nýr miði */
.lp-btn-primary{
  flex:1;
  display:flex;align-items:center;justify-content:center;gap:6px;
  padding:10px 10px;
  border:none;border-radius:10px;
  background:linear-gradient(135deg,var(--acc) 0%,#3d7a28 100%);
  color:#fff;
  font-family:'DM Sans',sans-serif;font-size:0.82rem;font-weight:700;
  cursor:pointer;
  box-shadow:0 2px 10px rgba(42,94,30,0.28),inset 0 1px 0 rgba(255,255,255,0.12);
  transition:all 0.18s cubic-bezier(0.34,1.2,0.64,1);
  letter-spacing:0.01em;
  position:relative;overflow:hidden;
  white-space:nowrap;
}
.lp-btn-primary::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,0.18) 50%,transparent 60%);
  transform:translateX(-110%);transition:transform 0.55s ease;
}
.lp-btn-primary:hover::after{transform:translateX(110%);}
.lp-btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 5px 18px rgba(42,94,30,0.40);
}
.lp-btn-primary:active{transform:scale(0.96)!important;}

/* Secondary — Prenta */
.lp-btn-secondary{
  display:flex;align-items:center;justify-content:center;gap:5px;
  padding:10px 12px;
  border:1.5px solid var(--border2);border-radius:10px;
  background:var(--s2);
  color:var(--text2);
  font-family:'DM Sans',sans-serif;font-size:0.8rem;font-weight:600;
  cursor:pointer;
  transition:all 0.16s cubic-bezier(0.34,1.2,0.64,1);
  white-space:nowrap;
}
.lp-btn-secondary:hover{
  background:var(--s3);color:var(--text);
  border-color:var(--border2);
  transform:translateY(-1px);
  box-shadow:0 2px 8px rgba(0,0,0,0.1);
}
.lp-btn-secondary:active{transform:scale(0.96)!important;}

/* Ghost — Hreinsa (X icon, danger hover) */
.lp-btn-ghost{
  display:flex;align-items:center;justify-content:center;
  width:36px;height:36px;flex-shrink:0;
  border:1.5px solid var(--border);border-radius:9px;
  background:transparent;
  color:var(--text3);
  cursor:pointer;
  transition:all 0.15s;
}
.lp-btn-ghost:hover{
  border-color:var(--red);
  color:var(--red);
  background:rgba(192,57,43,0.07);
  transform:scale(1.05);
}
.lp-btn-ghost:active{transform:scale(0.94)!important;}

[data-theme="dark"] .lp-brand{background:linear-gradient(135deg,rgba(42,94,30,0.08) 0%,transparent 80%);}
[data-theme="dark"] .lp-btn-secondary{background:#1c1c1c;border-color:#2e2e2e;}
[data-theme="dark"] .lp-live-pill{background:#181818;border-color:#2a2a2a;}

/* Mobile */
@media(max-width:768px){
  .lp-btn-primary{padding:11px 8px;font-size:0.85rem;}
  .lp-btn-secondary{padding:11px 10px;}
  .lp-btn-ghost{width:38px;height:38px;}
  .lp-brand-label{font-size:0.65rem;}
}


/* ═══ TB2 TOOLBAR ═══ */
.ctb-bar{padding:0 8px;border-bottom:1.5px solid var(--border);display:flex;align-items:stretch;gap:0;flex-shrink:0;background:linear-gradient(180deg,var(--s1) 0%,var(--s2) 100%);overflow-x:auto;overflow-y:hidden;position:relative;z-index:5;-webkit-overflow-scrolling:touch;white-space:nowrap;min-height:56px;}
.ctb-bar::-webkit-scrollbar{height:2px;}
.ctb-bar::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px;}
[data-theme="dark"] .ctb-bar{background:linear-gradient(180deg,#161616 0%,#111 100%);border-color:rgba(255,255,255,0.07);}
.tb2-group{display:flex;flex-direction:column;align-items:stretch;justify-content:center;padding:5px 7px;flex-shrink:0;}
.tb2-glabel{font-size:0.5rem;font-weight:800;letter-spacing:0.12em;text-transform:uppercase;color:var(--text3);opacity:0.7;padding:0 2px 4px;text-align:center;white-space:nowrap;}
.tb2-btns{display:flex;align-items:center;gap:2px;}
.tb2-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:5px 8px;min-width:44px;border-radius:9px;border:1.5px solid transparent;background:transparent;color:var(--text2);cursor:pointer;font-family:'DM Sans',sans-serif;transition:all 0.16s cubic-bezier(0.34,1.2,0.64,1);flex-shrink:0;user-select:none;}
.tb2-btn svg{width:16px;height:16px;pointer-events:none;flex-shrink:0;transition:transform 0.16s cubic-bezier(0.34,1.4,0.64,1);}
.tb2-btn span{font-size:0.55rem;font-weight:700;letter-spacing:0.03em;white-space:nowrap;color:inherit;line-height:1;text-transform:uppercase;}
.tb2-btn:hover{background:var(--s3);color:var(--text);border-color:var(--border2);transform:translateY(-1px);box-shadow:0 2px 8px rgba(0,0,0,0.09);}
.tb2-btn:hover svg{transform:scale(1.12);}
.tb2-btn:active{transform:translateY(0) scale(0.94)!important;transition:transform 0.07s!important;}
.tb2-btn.act{background:var(--acc-dim)!important;color:var(--acc)!important;border-color:rgba(42,94,30,0.25)!important;box-shadow:0 0 0 1.5px rgba(42,94,30,0.1),inset 0 1px 0 rgba(42,94,30,0.06)!important;}
.tb2-zoom{min-width:60px;padding:5px 10px;background:var(--s2)!important;border-color:var(--border2)!important;color:var(--text)!important;}
.tb2-zoom:hover{border-color:var(--acc)!important;background:var(--acc-dim)!important;color:var(--acc)!important;}
.tb2-sep{width:1.5px;background:var(--border);align-self:stretch;margin:10px 1px;flex-shrink:0;border-radius:2px;opacity:0.5;}
@media(max-width:900px){.ctb-bar{min-height:50px;padding:0 4px;}.tb2-group{padding:4px 4px;}.tb2-btn{min-width:36px;padding:4px 5px;}.tb2-glabel{font-size:0.45rem;}.tb2-btn span{font-size:0.5rem;}.tb2-btn svg{width:14px;height:14px;}}
@media(max-width:600px){.tb2-glabel{display:none;}.ctb-bar{min-height:44px;}.tb2-btn{min-width:32px;padding:5px 4px;}.tb2-btn span{display:none;}.tb2-btn svg{width:17px;height:17px;}}

/* ═══ CANVAS HEADER ═══ */
.canvas-header{height:46px;padding:0 14px;border-bottom:1.5px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;background:linear-gradient(135deg,var(--s1) 0%,var(--s2) 100%);position:relative;z-index:5;}
.ch-label-icon{width:26px;height:26px;border-radius:7px;background:var(--acc-dim);border:1px solid rgba(42,94,30,0.18);display:flex;align-items:center;justify-content:center;color:var(--acc);flex-shrink:0;}
.canvas-header .ph-title{font-size:0.76rem;font-weight:700;color:var(--text2);letter-spacing:0.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px;}
.ch-zoom-pill{font-family:'JetBrains Mono',monospace;font-size:0.68rem;font-weight:700;color:var(--text3);background:var(--s3);border:1px solid var(--border);padding:3px 8px;border-radius:6px;white-space:nowrap;}
.ch-print-btn{display:flex;align-items:center;justify-content:center;gap:5px;padding:7px 13px;border-radius:9px;border:none;background:linear-gradient(135deg,var(--acc) 0%,#3d7a28 100%);color:#fff;font-family:'DM Sans',sans-serif;font-size:0.76rem;font-weight:700;cursor:pointer;white-space:nowrap;box-shadow:0 2px 8px rgba(42,94,30,0.28),inset 0 1px 0 rgba(255,255,255,0.1);transition:all 0.16s cubic-bezier(0.34,1.2,0.64,1);}
.ch-print-btn:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(42,94,30,0.4);background:linear-gradient(135deg,#357a26 0%,var(--acc-light) 100%);}
.ch-print-btn:active{transform:scale(0.95);}
[data-theme="dark"] .canvas-header{background:linear-gradient(135deg,#161616 0%,#111 100%);border-color:rgba(255,255,255,0.07);}
[data-theme="dark"] .ch-zoom-pill{background:#1e1e1e;border-color:#2a2a2a;}

/* ═══ EMPTY STATE PILLS ═══ */
.es-pills{display:flex;flex-wrap:wrap;justify-content:center;gap:5px;margin-bottom:22px;}
.es-pill{font-size:0.63rem;font-weight:700;padding:4px 9px;border-radius:20px;background:var(--s3);color:var(--text2);border:1px solid var(--border);letter-spacing:0.02em;transition:all 0.15s;}
.es-pill.hot{background:rgba(42,94,30,0.1);color:var(--acc);border-color:rgba(42,94,30,0.22);}
[data-theme="dark"] .es-pill.hot{background:rgba(42,94,30,0.18);}

/* ═══════════════════════════════════════════════════════════════
   PRO MAX UI/UX REFINEMENTS (v1)
   Purely visual — no structural, logical, or JS-facing changes.
   All IDs, classes, and DOM remain untouched.
   ═══════════════════════════════════════════════════════════════ */

/* Typography rendering upgrade */
html,body{
  font-feature-settings:'kern','ss01','cv11';
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
.chip,.ch-zoom-pill,.dash-kpi,.dash-prod-count,.dash-recent-qty,
.sb-item,.sb-item b,.lp-live-pill,.upp-ingr-kg,.upp-ingr-pct,
#sb-x,#sb-y,#sb-size,#sb-zoom{
  font-variant-numeric:tabular-nums;
  font-feature-settings:'tnum','lnum','kern';
}

/* Selection — themed to brand */
::selection{background:rgba(42,94,30,0.22);color:var(--text);}
[data-theme="dark"] ::selection{background:rgba(53,122,38,0.35);color:#fff;}

/* Accessible focus rings without stealing from existing focus styles */
button:focus-visible,
.nb:focus-visible,.tp-btn:focus-visible,.tb2-btn:focus-visible,
.lp-btn-primary:focus-visible,.lp-btn-secondary:focus-visible,.lp-btn-ghost:focus-visible,
.ch-print-btn:focus-visible,.auth-btn:focus-visible,.user-btn:focus-visible,
.safn-doc-tab:focus-visible,.auth-tab:focus-visible{
  outline:2px solid rgba(42,94,30,0.55);
  outline-offset:2px;
}

/* Topbar — richer frost */
.topbar{
  background:linear-gradient(180deg,rgba(248,244,235,0.9) 0%,rgba(240,235,224,0.82) 100%);
  backdrop-filter:blur(32px) saturate(190%);
  -webkit-backdrop-filter:blur(32px) saturate(190%);
  border-bottom:1px solid rgba(191,185,175,0.55);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.7) inset,
    0 1px 2px rgba(0,0,0,0.03),
    0 8px 28px rgba(42,94,30,0.06);
}
[data-theme="dark"] .topbar{
  background:linear-gradient(180deg,rgba(22,22,22,0.78) 0%,rgba(17,17,17,0.72) 100%)!important;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.04) inset,
    0 1px 2px rgba(0,0,0,0.25),
    0 8px 28px rgba(0,0,0,0.3)!important;
}

/* Nav pill container */
.tcenter{
  background:linear-gradient(180deg,var(--s2) 0%,var(--s3) 100%);
  border:1px solid rgba(191,185,175,0.55);
  box-shadow:
    inset 0 1px 3px rgba(0,0,0,0.04),
    0 1px 0 rgba(255,255,255,0.5);
}
.nb{transition:background 0.25s cubic-bezier(0.22,1,0.36,1),color 0.22s ease,box-shadow 0.25s cubic-bezier(0.22,1,0.36,1),transform 0.2s cubic-bezier(0.34,1.3,0.64,1);}
.nb.active{
  background:linear-gradient(180deg,#357a26 0%,#2a5e1e 100%);
  box-shadow:
    0 2px 10px rgba(42,94,30,0.36),
    0 1px 2px rgba(42,94,30,0.2),
    inset 0 1px 0 rgba(255,255,255,0.2),
    inset 0 -1px 0 rgba(0,0,0,0.08);
}
.nb.active:hover{
  background:linear-gradient(180deg,#3d8a2d 0%,#2f6c24 100%);
  box-shadow:
    0 5px 18px rgba(42,94,30,0.42),
    0 2px 4px rgba(42,94,30,0.22),
    inset 0 1px 0 rgba(255,255,255,0.22);
}

/* User button — soft depth */
.user-btn{
  background:linear-gradient(180deg,var(--s2) 0%,var(--s3) 100%);
  box-shadow:0 1px 3px rgba(0,0,0,0.04),inset 0 1px 0 rgba(255,255,255,0.5);
}
.user-av{
  background:linear-gradient(135deg,#357a26 0%,#2a5e1e 100%);
  box-shadow:
    0 0 0 2px rgba(42,94,30,0.18),
    0 2px 6px rgba(42,94,30,0.22),
    inset 0 1px 0 rgba(255,255,255,0.2);
}

/* Panels — subtle inner depth */
.p-left{
  background:linear-gradient(180deg,var(--s1) 0%,#ebe5da 100%);
  box-shadow:inset -1px 0 0 rgba(191,185,175,0.5);
}
.p-right{
  background:linear-gradient(180deg,var(--s1) 0%,#ebe5da 100%);
  box-shadow:inset 1px 0 0 rgba(191,185,175,0.5);
}
.p-center{
  background:
    radial-gradient(ellipse 120% 60% at 50% -10%,rgba(42,94,30,0.055) 0%,transparent 60%),
    linear-gradient(180deg,#d9d2c5 0%,#cdc5b6 100%);
}
[data-theme="dark"] .p-left,[data-theme="dark"] .p-right{
  background:linear-gradient(180deg,#171717 0%,#131313 100%)!important;
  box-shadow:none!important;
}

/* Section cards — refined depth + smoother motion */
.fsec{
  background:linear-gradient(180deg,#f7f2e9 0%,#f1ebe0 100%);
  border:1px solid rgba(191,185,175,0.8);
  box-shadow:
    0 1px 2px rgba(15,25,10,0.04),
    0 4px 14px rgba(15,25,10,0.05),
    inset 0 1px 0 rgba(255,255,255,0.55);
  transition:box-shadow 0.28s cubic-bezier(0.22,1,0.36,1),
             border-color 0.28s cubic-bezier(0.22,1,0.36,1),
             transform 0.2s cubic-bezier(0.22,1,0.36,1);
}
.fsec:hover{
  border-color:rgba(42,94,30,0.25);
  box-shadow:
    0 2px 6px rgba(15,25,10,0.07),
    0 10px 28px rgba(42,94,30,0.08),
    inset 0 1px 0 rgba(255,255,255,0.6);
}
.fsec-title{
  background:linear-gradient(180deg,rgba(42,94,30,0.08) 0%,rgba(42,94,30,0.015) 100%);
  border-bottom:1px solid rgba(42,94,30,0.12);
  letter-spacing:0.06em;
}
.fsec-title-icon{
  background:linear-gradient(135deg,#357a26 0%,#2a5e1e 100%);
  box-shadow:
    0 2px 6px rgba(42,94,30,0.3),
    inset 0 1px 0 rgba(255,255,255,0.22);
}
[data-theme="dark"] .fsec{
  background:linear-gradient(180deg,#1b1b1b 0%,#161616 100%)!important;
  border-color:rgba(255,255,255,0.08)!important;
  box-shadow:
    0 1px 2px rgba(0,0,0,0.25),
    0 4px 14px rgba(0,0,0,0.18),
    inset 0 1px 0 rgba(255,255,255,0.03)!important;
}
[data-theme="dark"] .fsec-title{
  background:linear-gradient(180deg,rgba(53,122,38,0.14) 0%,rgba(53,122,38,0.02) 100%)!important;
  border-bottom-color:rgba(53,122,38,0.18)!important;
}

/* Inputs — cleaner, more refined */
.fi,.fi-ta,.fi-sel{
  background:#f8f4ec;
  border:1px solid rgba(191,185,175,0.8);
  box-shadow:inset 0 1px 2px rgba(0,0,0,0.04);
  transition:border-color 0.2s cubic-bezier(0.22,1,0.36,1),
             box-shadow 0.2s cubic-bezier(0.22,1,0.36,1),
             background 0.2s cubic-bezier(0.22,1,0.36,1);
}
.fi:hover,.fi-ta:hover,.fi-sel:hover{
  background:#fbf7ef;
  border-color:rgba(42,94,30,0.3);
}
.fi:focus,.fi-ta:focus,.fi-sel:focus{
  border-color:var(--acc);
  background:#fbf7ef;
  box-shadow:0 0 0 3.5px rgba(42,94,30,0.16),
             inset 0 1px 2px rgba(0,0,0,0.03);
  transform:none;
}

/* Primary action — Nýr miði */
.lp-btn-primary{
  background:linear-gradient(180deg,#357a26 0%,#2a5e1e 100%);
  box-shadow:
    0 2px 8px rgba(42,94,30,0.32),
    0 1px 2px rgba(42,94,30,0.18),
    inset 0 1px 0 rgba(255,255,255,0.2),
    inset 0 -1px 0 rgba(0,0,0,0.08);
  letter-spacing:0.015em;
}
.lp-btn-primary:hover{
  background:linear-gradient(180deg,#3d8a2d 0%,#2f6c24 100%);
  box-shadow:
    0 6px 20px rgba(42,94,30,0.44),
    0 2px 4px rgba(42,94,30,0.22),
    inset 0 1px 0 rgba(255,255,255,0.22);
}

/* Secondary action */
.lp-btn-secondary{
  background:linear-gradient(180deg,#f4efe6 0%,#e9e3d8 100%);
  border:1px solid rgba(191,185,175,0.9);
  box-shadow:0 1px 2px rgba(0,0,0,0.04),inset 0 1px 0 rgba(255,255,255,0.5);
}

/* Canvas header print */
.ch-print-btn{
  background:linear-gradient(180deg,#357a26 0%,#2a5e1e 100%);
  box-shadow:
    0 2px 8px rgba(42,94,30,0.3),
    inset 0 1px 0 rgba(255,255,255,0.2);
}
.ch-print-btn:hover{
  background:linear-gradient(180deg,#3d8a2d 0%,#2f6c24 100%);
  box-shadow:
    0 5px 16px rgba(42,94,30,0.42),
    inset 0 1px 0 rgba(255,255,255,0.22);
}

/* Dashboard cards — premium */
.dash-card{
  background:linear-gradient(180deg,#f7f2e9 0%,#f1ebe0 100%);
  border:1px solid rgba(191,185,175,0.8);
  box-shadow:
    0 1px 2px rgba(15,25,10,0.04),
    0 4px 14px rgba(15,25,10,0.05),
    inset 0 1px 0 rgba(255,255,255,0.5);
  transition:transform 0.24s cubic-bezier(0.22,1,0.36,1),
             box-shadow 0.24s cubic-bezier(0.22,1,0.36,1),
             border-color 0.24s cubic-bezier(0.22,1,0.36,1);
}
.dash-card:hover{
  transform:translateY(-2px);
  border-color:rgba(42,94,30,0.22);
  box-shadow:
    0 4px 10px rgba(15,25,10,0.06),
    0 12px 32px rgba(42,94,30,0.1),
    inset 0 1px 0 rgba(255,255,255,0.55);
}
.dash-kpi{
  font-weight:800;
  letter-spacing:-0.025em;
  background:linear-gradient(180deg,#1a2318 0%,#3a4e32 100%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
}
[data-theme="dark"] .dash-card{
  background:linear-gradient(180deg,#1b1b1b 0%,#161616 100%)!important;
  border-color:rgba(255,255,255,0.08)!important;
}
[data-theme="dark"] .dash-kpi{
  background:linear-gradient(180deg,#f0f0ea 0%,#b8c7b0 100%)!important;
  -webkit-background-clip:text!important;
  background-clip:text!important;
  -webkit-text-fill-color:transparent!important;
}

/* Chips — elegant */
.chip{
  background:linear-gradient(180deg,#f4efe6 0%,#ece6db 100%);
  border:1px solid rgba(191,185,175,0.8);
  box-shadow:0 1px 2px rgba(0,0,0,0.03);
}
.chip.hi{
  background:linear-gradient(180deg,rgba(42,94,30,0.14) 0%,rgba(42,94,30,0.06) 100%);
  border-color:rgba(42,94,30,0.32);
  box-shadow:0 1px 2px rgba(0,0,0,0.03),0 0 0 1px rgba(42,94,30,0.06);
}

/* Toolbar active state — more obvious */
.tb2-btn.act{
  background:linear-gradient(180deg,rgba(42,94,30,0.14) 0%,rgba(42,94,30,0.06) 100%)!important;
  border-color:rgba(42,94,30,0.3)!important;
  box-shadow:
    0 0 0 1px rgba(42,94,30,0.1),
    inset 0 1px 0 rgba(255,255,255,0.25)!important;
}

/* Auth screen — premium depth */
.auth-screen{
  background:var(--bg);
  background-image:
    radial-gradient(ellipse 80% 55% at 50% 0%,rgba(42,94,30,0.1) 0%,transparent 68%),
    radial-gradient(ellipse 70% 45% at 50% 100%,rgba(42,94,30,0.06) 0%,transparent 70%);
}
.auth-box{
  background:linear-gradient(180deg,#f8f3ea 0%,#f0ebe0 100%);
  border:1px solid rgba(191,185,175,0.85);
  box-shadow:
    0 20px 60px rgba(15,25,10,0.16),
    0 4px 16px rgba(15,25,10,0.08),
    inset 0 1px 0 rgba(255,255,255,0.7);
}
.auth-btn{
  background:linear-gradient(180deg,#357a26 0%,#2a5e1e 100%);
  box-shadow:
    0 2px 8px rgba(42,94,30,0.3),
    0 1px 2px rgba(42,94,30,0.18),
    inset 0 1px 0 rgba(255,255,255,0.2);
  letter-spacing:0.02em;
}
.auth-btn:hover{
  background:linear-gradient(180deg,#3d8a2d 0%,#2f6c24 100%);
  box-shadow:
    0 6px 20px rgba(42,94,30,0.44),
    inset 0 1px 0 rgba(255,255,255,0.22);
}

/* Scrollbar — refined */
.scroll::-webkit-scrollbar{width:6px;height:6px;}
.scroll::-webkit-scrollbar-thumb{
  background:rgba(140,130,115,0.38);
  border-radius:8px;
  transition:background 0.18s;
}
.scroll::-webkit-scrollbar-thumb:hover{background:rgba(42,94,30,0.5);}
[data-theme="dark"] .scroll::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.12);}
[data-theme="dark"] .scroll::-webkit-scrollbar-thumb:hover{background:rgba(53,122,38,0.5);}

/* Status bar — refined separator */
.sb-sep,.tsep,.tb2-sep{opacity:0.55;}

/* Type tuning — logo wordmark */
.logo-name{
  letter-spacing:0.1em;
  text-shadow:0 1px 0 rgba(255,255,255,0.4);
}
[data-theme="dark"] .logo-name{text-shadow:none;}

/* Canvas header — subtle depth */
.canvas-header{
  background:linear-gradient(180deg,#f4efe6 0%,#ebe5da 100%);
  box-shadow:0 1px 0 rgba(255,255,255,0.5) inset,0 1px 2px rgba(0,0,0,0.03);
}
.ch-label-icon{
  background:linear-gradient(180deg,rgba(42,94,30,0.14) 0%,rgba(42,94,30,0.06) 100%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.4);
}

/* Toolbar bar — refined */
.ctb-bar{
  background:linear-gradient(180deg,#f4efe6 0%,#e9e3d8 100%);
  box-shadow:0 1px 0 rgba(255,255,255,0.5) inset,0 1px 2px rgba(0,0,0,0.03);
}

/* Subtle motion calm-down on reduced-motion */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:0.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:0.01ms!important;
    scroll-behavior:auto!important;
  }
}

/* ═══════════════════════════════════════════════════════════════
   PRO MAX UI/UX — WOW FACTOR LAYER (v2)
   Animated aurora, cursor spotlight, glossy shine, spring motion.
   Pure visual layer — all interactions intact.
   ═══════════════════════════════════════════════════════════════ */

/* Animated CSS custom property for rotating conic gradients */
@property --angle{syntax:'<angle>';initial-value:0deg;inherits:false;}

/* Global animated aurora behind center canvas — very subtle */
.p-center{
  position:relative;
  overflow:hidden;
}
.p-center::before{
  content:'';
  position:absolute;inset:-20%;
  background:
    radial-gradient(ellipse 40% 30% at 20% 30%,rgba(42,94,30,0.16) 0%,transparent 60%),
    radial-gradient(ellipse 30% 40% at 80% 70%,rgba(26,111,186,0.1) 0%,transparent 60%),
    radial-gradient(ellipse 35% 35% at 50% 100%,rgba(212,112,10,0.08) 0%,transparent 65%);
  filter:blur(40px);
  opacity:0.7;
  pointer-events:none;
  z-index:0;
  animation:auroraDrift 22s ease-in-out infinite alternate;
}
@keyframes auroraDrift{
  0%{transform:translate(0,0) scale(1) rotate(0deg);}
  50%{transform:translate(2%,-2%) scale(1.05) rotate(4deg);}
  100%{transform:translate(-2%,2%) scale(0.98) rotate(-3deg);}
}
.canvas-center,.canvas-header,.ctb-bar,.ssb-header,.ssb-body,.canvas-wrap{position:relative;z-index:1;}
[data-theme="dark"] .p-center::before{
  background:
    radial-gradient(ellipse 40% 30% at 20% 30%,rgba(53,122,38,0.22) 0%,transparent 60%),
    radial-gradient(ellipse 30% 40% at 80% 70%,rgba(26,111,186,0.18) 0%,transparent 60%),
    radial-gradient(ellipse 35% 35% at 50% 100%,rgba(212,112,10,0.12) 0%,transparent 65%);
  opacity:0.55;
}

/* Primary CTA — living shine */
.lp-btn-primary,.ch-print-btn,.auth-btn{
  position:relative;overflow:hidden;isolation:isolate;
}
.lp-btn-primary::before,.ch-print-btn::before,.auth-btn::before{
  content:'';position:absolute;inset:-1px;z-index:-1;
  background:conic-gradient(from var(--angle),
    rgba(255,255,255,0) 0%,
    rgba(120,255,90,0.55) 8%,
    rgba(255,255,255,0) 18%,
    rgba(255,255,255,0) 100%);
  border-radius:inherit;
  opacity:0;
  transition:opacity 0.3s ease;
  animation:rotateAngle 3.5s linear infinite;
}
.lp-btn-primary:hover::before,.ch-print-btn:hover::before,.auth-btn:hover::before{opacity:1;}
@keyframes rotateAngle{to{--angle:360deg;}}

/* Breathing glow on primary CTA */
@keyframes breatheGlow{
  0%,100%{box-shadow:
    0 2px 8px rgba(42,94,30,0.32),
    0 1px 2px rgba(42,94,30,0.18),
    inset 0 1px 0 rgba(255,255,255,0.2),
    inset 0 -1px 0 rgba(0,0,0,0.08),
    0 0 0 rgba(53,122,38,0);}
  50%{box-shadow:
    0 2px 8px rgba(42,94,30,0.32),
    0 1px 2px rgba(42,94,30,0.18),
    inset 0 1px 0 rgba(255,255,255,0.2),
    inset 0 -1px 0 rgba(0,0,0,0.08),
    0 0 18px rgba(53,122,38,0.35);}
}
.lp-btn-primary{animation:breatheGlow 3.2s ease-in-out infinite;}
.lp-btn-primary:hover{animation:none;}

/* Section icon — pulsing aura ring */
.fsec-title-icon{position:relative;}
.fsec-title-icon::after{
  content:'';position:absolute;inset:-4px;border-radius:12px;
  background:conic-gradient(from var(--angle),
    rgba(53,122,38,0) 0%,
    rgba(53,122,38,0.5) 15%,
    rgba(53,122,38,0) 30%,
    rgba(53,122,38,0) 100%);
  opacity:0;transition:opacity 0.35s ease;
  animation:rotateAngle 4s linear infinite;
  z-index:-1;
}
.fsec:hover .fsec-title-icon::after{opacity:0.85;}

/* Cursor spotlight on section cards — light follows mouse */
.fsec::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(400px circle at var(--mx,-200px) var(--my,-200px),
    rgba(42,94,30,0.1) 0%,
    rgba(42,94,30,0.04) 20%,
    transparent 50%);
  border-radius:inherit;
  opacity:0;transition:opacity 0.35s ease;
  pointer-events:none;
  z-index:0;
}
.fsec:hover::before{opacity:1;}
.fsec>*{position:relative;z-index:1;}
.fsec{position:relative;}
[data-theme="dark"] .fsec::before{
  background:radial-gradient(400px circle at var(--mx,-200px) var(--my,-200px),
    rgba(53,122,38,0.16) 0%,
    rgba(53,122,38,0.05) 25%,
    transparent 55%);
}

/* Dashboard cards — spotlight + subtle tilt-ready */
.dash-card{position:relative;overflow:hidden;}
.dash-card::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(500px circle at var(--mx,-200px) var(--my,-200px),
    rgba(42,94,30,0.12) 0%,
    rgba(42,94,30,0.04) 22%,
    transparent 52%);
  border-radius:inherit;
  opacity:0;transition:opacity 0.35s ease;
  pointer-events:none;
}
.dash-card:hover::before{opacity:1;}
.dash-card>*{position:relative;z-index:1;}

/* Glossy shine sweep on section title */
.fsec-title{position:relative;overflow:hidden;}
.fsec-title::after{
  content:'';position:absolute;top:0;left:-70%;width:60%;height:100%;
  background:linear-gradient(105deg,
    transparent 0%,
    rgba(255,255,255,0.45) 50%,
    transparent 100%);
  transform:skewX(-18deg);
  transition:left 0.8s cubic-bezier(0.22,1,0.36,1);
  pointer-events:none;
}
.fsec:hover .fsec-title::after{left:140%;}
[data-theme="dark"] .fsec-title::after{background:linear-gradient(105deg,transparent 0%,rgba(255,255,255,0.08) 50%,transparent 100%);}

/* Nav active pill — aurora underline */
.nb.active{position:relative;overflow:visible;}
.nb.active::after{
  content:'';position:absolute;left:20%;right:20%;bottom:-6px;height:3px;
  background:linear-gradient(90deg,
    transparent 0%,
    rgba(53,122,38,0.9) 20%,
    rgba(120,200,80,1) 50%,
    rgba(53,122,38,0.9) 80%,
    transparent 100%);
  border-radius:4px;
  filter:blur(0.5px);
  box-shadow:0 0 8px rgba(53,122,38,0.6);
  animation:pulseUnderline 2.2s ease-in-out infinite;
}
@keyframes pulseUnderline{
  0%,100%{opacity:0.85;transform:scaleX(1);}
  50%{opacity:1;transform:scaleX(1.08);}
}

/* User avatar — subtle rotating aura */
.user-av{position:relative;}
.user-av::after{
  content:'';position:absolute;inset:-3px;border-radius:50%;
  background:conic-gradient(from var(--angle),
    rgba(53,122,38,0) 0%,
    rgba(120,200,80,0.6) 25%,
    rgba(53,122,38,0) 50%,
    rgba(53,122,38,0) 100%);
  opacity:0;transition:opacity 0.3s ease;
  animation:rotateAngle 4s linear infinite;
  z-index:-1;
}
.user-btn:hover .user-av::after{opacity:1;}

/* Topbar — aurora rim-light under */
.topbar::after{
  content:'';position:absolute;left:10%;right:10%;bottom:-1px;height:1px;
  background:linear-gradient(90deg,
    transparent 0%,
    rgba(53,122,38,0.55) 50%,
    transparent 100%);
  filter:blur(0.5px);
}

/* Input spring focus (no translate — keep caret stable) */
.fi:focus,.fi-ta:focus,.fi-sel:focus{
  animation:inputPop 0.4s cubic-bezier(0.34,1.4,0.64,1);
}
@keyframes inputPop{
  0%{box-shadow:0 0 0 0 rgba(42,94,30,0.3);}
  60%{box-shadow:0 0 0 8px rgba(42,94,30,0.0),0 0 0 3.5px rgba(42,94,30,0.18);}
  100%{box-shadow:0 0 0 3.5px rgba(42,94,30,0.16),inset 0 1px 2px rgba(0,0,0,0.03);}
}

/* Chips active — pulsing */
.chip.hi{
  animation:chipPulse 2.8s ease-in-out infinite;
}
@keyframes chipPulse{
  0%,100%{box-shadow:0 1px 2px rgba(0,0,0,0.03),0 0 0 1px rgba(42,94,30,0.06),0 0 0 rgba(42,94,30,0);}
  50%{box-shadow:0 1px 2px rgba(0,0,0,0.03),0 0 0 1px rgba(42,94,30,0.1),0 0 10px rgba(42,94,30,0.22);}
}

/* Auth logo — subtle float + glow */
.auth-logo-mark{animation:floatY 6s ease-in-out infinite;}
@keyframes floatY{
  0%,100%{transform:translateY(0);}
  50%{transform:translateY(-4px);}
}
.auth-logo-text{
  background:linear-gradient(180deg,#1a2318 0%,#3a4e32 100%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
}
.auth-logo-text span{
  background:linear-gradient(180deg,#357a26 0%,#2a5e1e 100%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
}
[data-theme="dark"] .auth-logo-text{
  background:linear-gradient(180deg,#f0f0ea 0%,#b8c7b0 100%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
}

/* Auth screen — animated aurora */
.auth-screen::after{
  content:'';position:absolute;inset:-10%;pointer-events:none;z-index:0;
  background:
    radial-gradient(ellipse 40% 30% at 30% 20%,rgba(42,94,30,0.14) 0%,transparent 60%),
    radial-gradient(ellipse 35% 30% at 70% 80%,rgba(26,111,186,0.1) 0%,transparent 60%);
  filter:blur(50px);
  animation:auroraDrift 18s ease-in-out infinite alternate;
}
.auth-box{position:relative;z-index:1;}

/* Dashboard KPI — subtle flicker when hovered */
.dash-card:hover .dash-kpi{
  animation:kpiShine 0.8s cubic-bezier(0.22,1,0.36,1);
}
@keyframes kpiShine{
  0%{filter:brightness(1);}
  50%{filter:brightness(1.15) drop-shadow(0 2px 8px rgba(42,94,30,0.3));}
  100%{filter:brightness(1);}
}

/* Smooth stagger when sections appear */
.fsec{
  animation:sectionRise 0.55s cubic-bezier(0.22,1,0.36,1) both;
}
@keyframes sectionRise{
  0%{opacity:0;transform:translateY(12px) scale(0.985);}
  100%{opacity:1;transform:translateY(0) scale(1);}
}
.fsec:nth-child(1){animation-delay:0.02s;}
.fsec:nth-child(2){animation-delay:0.08s;}
.fsec:nth-child(3){animation-delay:0.14s;}
.fsec:nth-child(4){animation-delay:0.2s;}
.fsec:nth-child(5){animation-delay:0.26s;}
.fsec:nth-child(6){animation-delay:0.32s;}
.fsec:nth-child(7){animation-delay:0.38s;}
.fsec:nth-child(8){animation-delay:0.44s;}

/* Topbar nav — subtle entry */
.topbar{animation:topbarSlide 0.5s cubic-bezier(0.22,1,0.36,1) both;}
@keyframes topbarSlide{
  0%{opacity:0;transform:translateY(-8px);}
  100%{opacity:1;transform:translateY(0);}
}

/* Button ripple-ish glow on click */
.lp-btn-primary:active::after,.ch-print-btn:active::after,.auth-btn:active::after{
  content:'';position:absolute;inset:0;border-radius:inherit;
  background:radial-gradient(circle at center,rgba(255,255,255,0.35) 0%,transparent 60%);
  animation:ripplePop 0.5s ease-out;
  pointer-events:none;
}
@keyframes ripplePop{
  0%{opacity:1;transform:scale(0.4);}
  100%{opacity:0;transform:scale(1);}
}

/* Toolbar buttons — micro-spring on hover */
.tb2-btn{transition:transform 0.22s cubic-bezier(0.34,1.5,0.64,1),background 0.18s ease,color 0.18s ease,border-color 0.18s ease,box-shadow 0.22s ease;}
.tb2-btn:hover{transform:translateY(-2px) scale(1.04);}

/* Template buttons — smoother spring */
.tp-btn{transition:transform 0.22s cubic-bezier(0.34,1.4,0.64,1),background 0.2s ease,color 0.2s ease,border-color 0.2s ease,box-shadow 0.25s ease;}
.tp-btn:hover{transform:translateY(-2px) scale(1.02);}
.tp-btn.tp-active{
  animation:tpActivate 0.5s cubic-bezier(0.34,1.4,0.64,1);
}
@keyframes tpActivate{
  0%{transform:scale(1);}
  50%{transform:scale(1.06);}
  100%{transform:scale(1);}
}

/* Logo wordmark — subtle gradient shift */
.logo-name{
  background:linear-gradient(180deg,#1a2318 0%,#3a4e32 100%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
  text-shadow:none;
}
[data-theme="dark"] .logo-name{
  background:linear-gradient(180deg,#f0f0ea 0%,#b8c7b0 100%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
}

/* Custom cursor feel — subtle */
.lp-btn-primary,.ch-print-btn,.auth-btn,.nb,.tb2-btn,.tp-btn,.user-btn,.dash-card{
  will-change:transform;
}

/* Empty-state — living pills */
.es-pill{transition:all 0.25s cubic-bezier(0.22,1,0.36,1);}
.es-pill:hover{transform:translateY(-2px) scale(1.04);box-shadow:0 4px 12px rgba(42,94,30,0.18);}

/* Better status bar */
.status-bar,.ssb-header,.ssb-body{
  backdrop-filter:blur(10px) saturate(160%);
  -webkit-backdrop-filter:blur(10px) saturate(160%);
}

/* Glassier umenu dropdown */
.umenu{
  backdrop-filter:blur(28px) saturate(180%);
  -webkit-backdrop-filter:blur(28px) saturate(180%);
  background:linear-gradient(180deg,rgba(248,244,235,0.92) 0%,rgba(240,235,224,0.88) 100%)!important;
  border:1px solid rgba(191,185,175,0.6)!important;
  box-shadow:
    0 20px 60px rgba(15,25,10,0.2),
    0 4px 16px rgba(15,25,10,0.1),
    inset 0 1px 0 rgba(255,255,255,0.6)!important;
}
[data-theme="dark"] .umenu{
  background:linear-gradient(180deg,rgba(22,22,22,0.9) 0%,rgba(17,17,17,0.85) 100%)!important;
  border:1px solid rgba(255,255,255,0.08)!important;
}

