:root{--navy:#0f2a44;--ink:#1d2d3d;--muted:#657a94;--line:#d8e3ec;--bg:#f3f7fb;--card:#fff;--blue:#006eb6;--blue-2:#0b7cc6;--green:#2e7d6d;--purple:#7357b8;--amber:#9a6b00;--red:#b42318;--shadow:0 16px 45px rgba(15,42,68,.09);--shadow-soft:0 8px 25px rgba(15,42,68,.06);--radius:20px}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;background:radial-gradient(circle at top left,#eef8f7 0,#f3f7fb 30%,#f7f9fc 100%);color:var(--ink);font-size:16px;line-height:1.55;font-weight:400}a{color:#005ea8;text-decoration:none}a:hover{text-decoration:none;color:#003f73}.topbar{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;gap:20px;padding:12px 26px;background:rgba(255,255,255,.88);backdrop-filter:saturate(1.3) blur(16px);border-bottom:1px solid rgba(216,227,236,.9)}.brand{display:flex;align-items:center;gap:12px;color:var(--navy)}.brand-mark{width:44px;height:44px;border-radius:14px;background:linear-gradient(145deg,#006eb6,#2e7d6d);color:#fff;display:grid;place-items:center;font-weight:650;box-shadow:0 10px 22px rgba(0,110,182,.22)}.brand strong{display:block;font-size:1.05rem;font-weight:650;letter-spacing:.01em}.brand small{display:block;color:var(--muted);font-size:.83rem}.main-nav{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.main-nav a{padding:9px 12px;border-radius:999px;color:#005a9c;font-weight:500}.main-nav a.active{background:#e8f3fb;color:#073b63}.menu-toggle{display:none;border:1px solid var(--line);background:#fff;border-radius:12px;padding:9px 12px;color:var(--navy)}.wrap{max-width:1220px;margin:0 auto;padding:36px 28px}.footer{margin:52px 0 22px;padding-top:18px;border-top:1px solid var(--line);color:var(--muted);font-size:.9rem}.page-head{display:flex;justify-content:space-between;align-items:flex-start;gap:28px;margin:8px 0 28px}.page-head h1{margin:.15rem 0 .4rem;color:var(--navy);font-size:clamp(2rem,4vw,3.1rem);line-height:1.03;letter-spacing:-.035em;font-weight:650}.page-head p{color:var(--muted);font-size:1.08rem;max-width:820px;margin:.5rem 0 0}.eyebrow{text-transform:uppercase;letter-spacing:.16em;color:var(--green);font-size:.74rem;font-weight:650}.hero-panel{background:linear-gradient(135deg,#fff,#f3fbfa);border:1px solid var(--line);border-radius:28px;padding:30px;box-shadow:var(--shadow);margin-bottom:24px}.card,.module-card,.login-card{background:rgba(255,255,255,.94);border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-soft)}.card{margin-bottom:20px}.module-card{display:block;color:var(--ink);transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease;min-height:148px}.module-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:#b7d6ea}.module-card h2,.card h2{margin:.1rem 0 .75rem;color:var(--navy);font-size:1.25rem;font-weight:650;letter-spacing:-.015em}.module-card p,.muted,.empty{color:var(--muted)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--line);border-radius:13px;padding:10px 15px;background:#fff;color:var(--navy);font-weight:600;cursor:pointer;min-height:42px}.btn:hover{box-shadow:var(--shadow-soft)}.btn.primary{background:linear-gradient(135deg,#006eb6,#0879c7);border-color:#006eb6;color:#fff}.btn.success{background:#eaf7f2;border-color:#bfe2d5;color:#1b5c4f}.btn.small{padding:6px 10px;min-height:32px;border-radius:10px;font-size:.9rem}.button-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.notice{background:#eaf7f2;border:1px solid #bfe2d5;color:#174f43;border-radius:15px;padding:14px 16px;margin:0 0 20px}.stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin:18px 0 22px}.stat-card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:20px;box-shadow:var(--shadow-soft);position:relative;overflow:hidden}.stat-card:after{content:"";position:absolute;right:-30px;top:-30px;width:90px;height:90px;background:#e8f3fb;border-radius:999px}.stat-card strong{display:block;color:#0064a8;font-size:2.15rem;line-height:1;font-weight:650;position:relative}.stat-card span{display:block;color:var(--muted);margin-top:8px;position:relative}.grid2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px}.grid3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.wide{grid-column:1/-1}label{display:grid;gap:7px;color:var(--navy);font-weight:600}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:13px;padding:12px 13px;font:inherit;color:var(--ink);background:#fff}input:focus,select:focus,textarea:focus{outline:3px solid #cfe8f7;border-color:#459fd6}textarea{resize:vertical}.check{display:flex;align-items:center;gap:9px}.check input{width:auto}.table-card{overflow:hidden;padding:0}.table-scroll{overflow:auto}table{width:100%;border-collapse:collapse;min-width:820px}th,td{text-align:left;padding:15px 16px;border-bottom:1px solid var(--line);vertical-align:top}th{font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);background:#f7fafc;font-weight:650}tbody tr:hover{background:#fbfdff}.pill{display:inline-flex;align-items:center;gap:5px;border-radius:999px;padding:5px 10px;font-size:.78rem;font-weight:650;background:#eef3f7;color:#35526b}.pill.ok,.pill.green{background:#e7f6ef;color:#17634f}.pill.blue{background:#e8f3fb;color:#075a95}.pill.purple{background:#f0edfb;color:#513b8d}.pill.warn{background:#fff4d9;color:#775200}.pill.dark{background:#e9edf2;color:#25384a}.pill.neutral{background:#eef3f7;color:#4c6176}.clean-list{list-style:none;padding:0;margin:0}.clean-list li{padding:12px 0;border-bottom:1px solid var(--line)}.clean-list li:last-child{border-bottom:0}.clean-list span{display:block;color:var(--muted);font-size:.92rem}.actions{white-space:nowrap}.actions a,.link-button{margin-right:10px}.link-button{border:0;background:transparent;color:#005ea8;font:inherit;cursor:pointer;padding:0}.empty-state{text-align:center;border:1px dashed #b9cbd9;border-radius:22px;background:#fbfdff;padding:34px}.empty-icon{width:54px;height:54px;margin:0 auto 12px;border-radius:18px;background:linear-gradient(135deg,#e8f3fb,#eaf7f2);display:grid;place-items:center;color:#006eb6}.admin-layout{display:grid;grid-template-columns:260px minmax(0,1fr);gap:22px}.admin-side{position:sticky;top:86px;align-self:start}.admin-side a{display:block;padding:11px 12px;border-radius:12px;color:var(--navy);font-weight:500}.admin-side a.active,.admin-side a:hover{background:#e8f3fb;color:#005a9c}.admin-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.question-row{border:1px solid var(--line);border-radius:16px;padding:16px;margin:12px 0;background:#fff}.question-row header{display:flex;justify-content:space-between;gap:12px}.builder-layout{display:grid;grid-template-columns:minmax(0,1.2fr) 360px;gap:22px}.info-box,.privacy{background:#eef8ff;border:1px solid #c7e5f7;border-radius:16px;padding:15px;color:#31546e}.survey-public{margin:-36px -28px;min-height:calc(100vh - 74px);padding:46px 20px;background:linear-gradient(150deg,#fafdff,#eef8f7)}.survey-shell{max-width:820px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:28px;padding:34px;box-shadow:var(--shadow)}.survey-shell h1{font-size:clamp(2rem,5vw,3.2rem);line-height:1.05;color:var(--navy);letter-spacing:-.035em}.answer-block{border:1px solid var(--line);border-radius:18px;padding:18px;margin:18px 0;background:#fff}.answer-block legend{font-weight:650;color:var(--navy);padding:0 8px}.choice{display:flex;align-items:center;gap:10px;padding:8px 0;font-weight:500}.choice input{width:auto}.scale{display:flex;flex-wrap:wrap;gap:8px}.scale label{display:block}.scale input{position:absolute;opacity:0}.scale span{display:grid;place-items:center;width:44px;height:44px;border-radius:13px;border:1px solid var(--line);font-weight:650}.scale input:checked+span{background:#006eb6;color:#fff}.result-grid{display:grid;grid-template-columns:1fr;gap:20px}.result-card{position:relative}.chart-list{display:grid;gap:14px}.chart-row{display:grid;grid-template-columns:230px 1fr;gap:16px;align-items:center}.chart-label span{font-weight:650;color:var(--navy)}.chart-label small{display:block;color:var(--muted)}.chart-track{height:34px;border-radius:999px;background:#edf3f7;overflow:hidden;border:1px solid var(--line)}.chart-track span{display:block;height:100%;background:linear-gradient(90deg,#006eb6,#2e7d6d);border-radius:999px}.text-answers{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.text-answers article{background:#f8fafc;border:1px solid var(--line);border-radius:16px;padding:15px}code{background:#eef3f7;border:1px solid var(--line);border-radius:9px;padding:3px 7px;word-break:break-all}.inline-form{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:8px}.inline-form.stack{display:grid;gap:12px}.mini-form{display:inline}.copy-link{display:flex;gap:8px;align-items:center}.copy-link code{max-width:360px;display:inline-block}@media(max-width:980px){.grid3,.stats,.admin-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.builder-layout,.admin-layout{grid-template-columns:1fr}.admin-side{position:static}.page-head{flex-direction:column}.main-nav{display:none;position:absolute;left:14px;right:14px;top:68px;background:#fff;border:1px solid var(--line);border-radius:18px;padding:12px;box-shadow:var(--shadow)}.main-nav.open{display:grid}.menu-toggle{display:inline-flex;margin-left:auto}.topbar{position:sticky}.brand small{display:none}}@media(max-width:720px){.wrap{padding:24px 16px}.grid2,.grid3,.stats,.form-grid,.admin-strip{grid-template-columns:1fr}.topbar{padding:10px 14px}.page-head h1{font-size:2rem}.card,.module-card{padding:18px}.chart-row{grid-template-columns:1fr}.text-answers{grid-template-columns:1fr}.button-row .btn{flex:1}.survey-public{margin:-24px -16px}.copy-link{display:grid}table{min-width:760px}}
/* UDDE 0.0.7-DEV UX polish */
.side-title{font-size:.72rem;text-transform:uppercase;letter-spacing:.16em;color:var(--green);font-weight:650;margin:2px 8px 12px}.admin-side{padding:14px}.admin-side a{display:grid;gap:2px;margin:2px 0;border:1px solid transparent}.admin-side a span{font-weight:620}.admin-side a small{display:block;color:var(--muted);font-size:.78rem;line-height:1.25}.admin-side a.active{border-color:#cfe4f3;box-shadow:inset 3px 0 0 #006eb6}.admin-content>.card:first-child,.admin-content>.grid2:first-child,.admin-content>.grid3:first-child,.admin-content>.stats:first-child{margin-top:0}.admin-strip>div{background:#fff;border:1px solid var(--line);border-radius:18px;padding:18px;box-shadow:var(--shadow-soft)}.admin-strip strong{display:block;color:#0064a8;font-size:1.75rem;line-height:1;font-weight:650}.admin-strip span{display:block;color:var(--muted);font-size:.9rem;margin-bottom:8px}.page-head .btn{white-space:nowrap}.module-card:focus-visible,.btn:focus-visible,.main-nav a:focus-visible,.admin-side a:focus-visible{outline:3px solid #cfe8f7;outline-offset:2px}.table-card table td .pill{white-space:nowrap}.actions{min-width:170px}.actions a,.link-button{display:inline-flex;margin:3px 7px 3px 0}.clean-list a{font-weight:600}.card h2+ul,.card h2+p{margin-top:.35rem}.notice{box-shadow:var(--shadow-soft)}
@media(max-width:980px){.admin-side{position:relative;top:auto;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.side-title{grid-column:1/-1}.admin-side a{margin:0}.admin-side a small{display:none}}
@media(max-width:560px){.admin-side{grid-template-columns:1fr}.topbar{gap:8px}.brand-mark{width:38px;height:38px}.main-nav a{padding:10px 12px}.page-head{gap:14px}.page-head .button-row,.page-head .btn{width:100%}.page-head .button-row .btn{flex:1}.stat-card{padding:17px}.stat-card strong{font-size:1.85rem}}

/* UDDE 0.0.8-DEV — polished UX, card navigation and responsive builder */
:root{--accent:#0078bf;--accent2:#2b8f83;--surface:#fff;--surface2:#f7fbfd;--soft:#eef7fb;--ring:#bfe3f7;--danger:#b42318;--ok:#167a5a;--warning:#8a5a00}.ico{width:18px;height:18px;flex:0 0 auto}.brand-mark{box-shadow:0 10px 22px rgba(0,105,160,.22)}.main-nav a{display:inline-flex;align-items:center;gap:7px}.main-nav a.active{box-shadow:inset 0 0 0 1px rgba(0,111,182,.08)}.user-link{max-width:260px}.page-head{margin-bottom:28px}.page-head .eyebrow{margin-bottom:.45rem;display:inline-block}.page-head .button-row{align-self:flex-start}.hero-panel{position:relative;overflow:hidden}.hero-panel:after{content:"";position:absolute;right:-70px;top:-90px;width:250px;height:250px;border-radius:999px;background:radial-gradient(circle,#dff2ef,transparent 70%);pointer-events:none}.section-title{display:flex;align-items:center;justify-content:space-between;gap:16px;margin:0 0 14px}.section-title h2{margin:0}.quick-actions{display:flex;gap:10px;flex-wrap:wrap}.survey-card-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.survey-card{background:#fff;border:1px solid var(--line);border-radius:24px;padding:20px;box-shadow:var(--shadow-soft);display:grid;gap:16px;transition:transform .14s ease,box-shadow .14s ease}.survey-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.survey-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.survey-card h2{font-size:1.3rem;margin:.1rem 0 .25rem}.survey-meta{display:flex;gap:8px;flex-wrap:wrap}.survey-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.metric{background:#f7fafc;border:1px solid var(--line);border-radius:16px;padding:12px}.metric strong{display:block;color:#0064a8;font-size:1.35rem}.metric span{display:block;color:var(--muted);font-size:.84rem}.share-box{display:grid;gap:8px}.share-box code{display:block;max-width:100%;overflow:hidden;text-overflow:ellipsis}.survey-actions{display:flex;gap:8px;flex-wrap:wrap}.survey-actions a,.survey-actions button{margin:0}.builder-steps{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;margin-bottom:18px}.builder-step{background:#fff;border:1px solid var(--line);border-radius:16px;padding:12px;display:flex;gap:10px;align-items:center;color:var(--navy)}.builder-step b{display:grid;place-items:center;width:28px;height:28px;border-radius:10px;background:#e8f3fb;color:#006eb6}.builder-step span{font-weight:650}.builder-step small{display:block;color:var(--muted);font-weight:500}.builder-card{border:1px solid var(--line);border-radius:24px;background:#fff;box-shadow:var(--shadow-soft);margin-bottom:20px;overflow:hidden}.builder-card-header{padding:18px 20px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;gap:16px;background:linear-gradient(135deg,#fff,#f8fcff)}.builder-card-header h2{margin:0;font-size:1.2rem}.builder-card-body{padding:20px}.question-list{display:grid;gap:12px}.question-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:16px;display:grid;gap:10px}.question-card:hover{border-color:#b9d9eb}.question-card-top{display:flex;gap:12px;align-items:flex-start;justify-content:space-between}.question-number{width:34px;height:34px;border-radius:12px;background:#e8f3fb;color:#006eb6;display:grid;place-items:center;font-weight:700;flex:0 0 auto}.question-title{display:flex;gap:12px;align-items:flex-start}.question-title b{font-size:1.05rem}.question-actions{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}.question-options{display:flex;gap:8px;flex-wrap:wrap}.question-options span{background:#f4f7fa;border:1px solid var(--line);border-radius:999px;padding:5px 10px;color:var(--muted);font-size:.9rem}.publish-check{display:grid;gap:10px}.check-item{display:flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:14px;padding:11px 12px;background:#fff}.check-item.ok{border-color:#bfe2d5;background:#f4fbf8}.check-dot{width:22px;height:22px;border-radius:999px;display:grid;place-items:center;background:#eef3f7;color:#60758a;font-weight:700}.check-item.ok .check-dot{background:#dff3ea;color:#167a5a}.progress{height:12px;border-radius:999px;background:#e9f0f5;overflow:hidden;border:1px solid var(--line)}.progress span{display:block;height:100%;background:linear-gradient(90deg,#0078bf,#2b8f83);border-radius:999px}.result-summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:20px}.result-summary .metric{background:#fff}.timeline-chart{display:flex;align-items:flex-end;gap:8px;min-height:150px;padding:18px 8px 6px;border:1px solid var(--line);border-radius:18px;background:linear-gradient(180deg,#fbfdff,#f5f9fb)}.timeline-bar{flex:1;min-width:18px;background:linear-gradient(180deg,#0078bf,#2b8f83);border-radius:10px 10px 4px 4px;position:relative}.timeline-bar small{position:absolute;bottom:-24px;left:50%;transform:translateX(-50%);font-size:.72rem;color:var(--muted);white-space:nowrap}.template-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.template-card{background:#fff;border:1px solid var(--line);border-radius:24px;padding:22px;box-shadow:var(--shadow-soft);display:grid;gap:14px}.template-card .btn{justify-self:start}.admin-side a span{display:flex;align-items:center;gap:9px}.admin-side a.active span{color:#005a9c}.admin-layout{align-items:start}.admin-content{min-width:0}.admin-note{background:#f7fafc;border:1px solid var(--line);border-radius:14px;padding:12px;color:var(--muted)}.risk-hint{display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:start;background:#fff8e6;border:1px solid #f1d291;color:#4e3900;border-radius:16px;padding:14px}.mobile-card-list{display:none}@media(max-width:1040px){.survey-card-grid,.template-grid{grid-template-columns:1fr}.builder-steps{grid-template-columns:repeat(2,minmax(0,1fr))}.result-summary{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:780px){.desktop-table{display:none}.mobile-card-list{display:grid;gap:14px}.survey-card-grid{gap:14px}.survey-metrics{grid-template-columns:1fr 1fr}.builder-steps{grid-template-columns:1fr}.question-card-top{display:grid}.question-actions{justify-content:flex-start}.result-summary{grid-template-columns:1fr}.timeline-chart{overflow-x:auto}.timeline-bar{min-width:34px}.topbar .brand span:last-child{display:none}.main-nav a .ico{display:none}.main-nav.open a{display:flex}.wrap{padding-bottom:70px}.sticky-mobile-actions{position:sticky;bottom:12px;z-index:5;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);padding:10px;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow)}}
.udde-toast{position:fixed;left:50%;bottom:22px;transform:translate(-50%,20px);background:#102b43;color:#fff;padding:12px 18px;border-radius:999px;box-shadow:0 18px 45px rgba(16,43,67,.25);opacity:0;transition:.18s ease;z-index:50}.udde-toast.show{opacity:1;transform:translate(-50%,0)}

/* UDDE 0.1.1-DEV — premium municipal SaaS UX */
:root{
  --page-max:1180px;
  --shadow-premium:0 24px 70px rgba(16,43,67,.10);
  --shadow-hover:0 28px 80px rgba(16,43,67,.15);
}
.wrap{max-width:var(--page-max);}
.topbar{backdrop-filter:saturate(1.4) blur(14px);background:rgba(255,255,255,.88);}
.main-nav a{min-height:38px;border-radius:999px;transition:background .16s ease,transform .16s ease,box-shadow .16s ease;}
.main-nav a:hover{transform:translateY(-1px);background:#eef7fb;}
.premium-card,.card,.survey-card,.template-card,.builder-card{transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease;}
.premium-card:hover,.survey-card:hover,.template-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-hover);}
.premium-hero{border-radius:32px;background:linear-gradient(135deg,rgba(255,255,255,.94),rgba(229,247,246,.72));box-shadow:var(--shadow-premium);}
.premium-stats .stat-card{position:relative;overflow:hidden;min-height:112px;}
.stat-icon{position:absolute;right:18px;top:18px;width:46px;height:46px;border-radius:18px;background:#e8f3fb;color:#006eb6;display:grid;place-items:center;opacity:.9}.stat-icon .ico{width:22px;height:22px}.dashboard-grid{display:grid;grid-template-columns:1.25fr .85fr;gap:20px}.dashboard-grid .card{min-height:220px}.dashboard-grid .card:nth-child(3),.dashboard-grid .card:nth-child(4){min-height:180px}.mini-survey-list{display:grid;gap:10px}.mini-survey{display:flex;justify-content:space-between;gap:16px;align-items:center;padding:14px;border:1px solid var(--line);border-radius:18px;background:linear-gradient(135deg,#fff,#f8fcff);text-decoration:none;color:var(--navy)}.mini-survey:hover{border-color:#b9d9eb;box-shadow:var(--shadow-soft)}.mini-survey strong{display:block}.mini-survey small{color:var(--muted)}.mini-survey em{font-style:normal;color:#006eb6;font-weight:700;white-space:nowrap}.action-stack{display:grid;gap:12px}.action-stack a{display:grid;gap:4px;padding:14px 16px;border:1px solid var(--line);border-radius:18px;background:#fff;text-decoration:none;color:var(--navy)}.action-stack a:hover{background:#f7fbfd;border-color:#b9d9eb}.action-stack span{color:var(--muted)}.insight-card{background:linear-gradient(135deg,#fff,#f3fbf8)}
.login-shell{display:grid;grid-template-columns:1fr 520px;gap:26px;align-items:stretch;margin-top:28px}.login-hero-panel{padding:44px;border-radius:34px;background:radial-gradient(circle at top right,#dff2ef,transparent 38%),linear-gradient(135deg,#fff,#f4fbff);border:1px solid var(--line);box-shadow:var(--shadow-premium)}.login-hero-panel h1{font-size:4rem;margin:.2rem 0}.lead{font-size:1.2rem;color:var(--muted);max-width:620px}.login-benefits{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:34px}.login-benefits div{padding:18px;border:1px solid var(--line);border-radius:20px;background:rgba(255,255,255,.72)}.login-benefits span{display:block;color:#2b8f83;font-size:.8rem;letter-spacing:.12em;font-weight:700}.login-benefits strong{display:block;margin-top:6px}.login-benefits small{display:block;color:var(--muted);margin-top:4px}.login-card{padding:34px}.card-kicker,.mini-label{text-transform:uppercase;letter-spacing:.12em;font-size:.74rem;color:var(--green);font-weight:700}.btn.big{padding:14px 22px;font-size:1rem}.security-strip{display:flex;align-items:flex-start;gap:10px;background:#f4fbf8;border:1px solid #cfe9df;border-radius:16px;padding:12px;color:#245d4b;margin-top:18px}.security-strip .ico{margin-top:2px}
.account-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:20px}.profile-card{text-align:center;padding:34px}.avatar-xl{width:86px;height:86px;border-radius:30px;background:linear-gradient(135deg,#0078bf,#2b8f83);display:grid;place-items:center;color:#fff;font-size:2.3rem;font-weight:750;margin:0 auto 18px;box-shadow:0 18px 40px rgba(0,120,191,.24)}.profile-badges{display:flex;justify-content:center;gap:8px;flex-wrap:wrap}.security-overview{padding:28px}.security-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.security-grid div{padding:16px;border:1px solid var(--line);border-radius:18px;background:#f9fcfe}.security-grid strong{display:block;margin-top:4px}.password-panel{grid-column:1/-1}.audit-toolbar{margin-bottom:18px}.filter-row{display:grid;grid-template-columns:1fr 260px auto auto;gap:12px;align-items:end}.timeline-card{background:#fff;border:1px solid var(--line);border-radius:24px;padding:20px;box-shadow:var(--shadow-soft)}.timeline-day{font-size:.86rem;text-transform:uppercase;letter-spacing:.12em;color:var(--green);margin:12px 0}.timeline-item{display:grid;grid-template-columns:28px 1fr;gap:14px;position:relative;padding:0 0 18px}.timeline-item:before{content:"";position:absolute;left:13px;top:24px;bottom:0;width:2px;background:#e1edf4}.timeline-item:last-child:before{display:none}.timeline-dot{width:28px;height:28px;border-radius:999px;background:#eef3f7;border:6px solid #fff;box-shadow:0 0 0 1px var(--line);z-index:1}.timeline-item.ok .timeline-dot{background:#dff3ea}.timeline-item.blue .timeline-dot{background:#dff0fb}.timeline-item.warn .timeline-dot{background:#fff1c7}.timeline-item.danger .timeline-dot{background:#ffd9d6}.timeline-body{border:1px solid var(--line);border-radius:18px;padding:14px 16px;background:#fbfdff}.timeline-main{display:flex;justify-content:space-between;gap:12px}.timeline-main span{color:var(--muted);font-size:.9rem}.timeline-body p{margin:.35rem 0;color:var(--muted)}.timeline-body small{color:#60758a}.result-hero{display:flex;justify-content:space-between;align-items:center;gap:24px;background:linear-gradient(135deg,#fff,#f4fbff)}.donut{width:132px;height:132px;border-radius:50%;background:conic-gradient(#0078bf calc(var(--value)*1%), #e8f0f5 0);display:grid;place-items:center;position:relative;flex:0 0 auto}.donut:after{content:"";position:absolute;inset:14px;border-radius:50%;background:#fff}.donut span,.donut small{position:relative;z-index:1}.donut span{font-size:1.7rem;font-weight:800;color:#0064a8}.donut small{display:block;grid-row:2;color:var(--muted);margin-top:-45px}.premium-chart{min-height:180px}.timeline-bar span{position:absolute;top:-24px;left:50%;transform:translateX(-50%);font-weight:700;color:#0064a8}.live-preview-card{position:sticky;top:96px}.phone-preview{border:1px solid var(--line);border-radius:28px;background:linear-gradient(180deg,#fff,#f7fbfd);padding:20px;margin:12px 0;box-shadow:inset 0 0 0 8px #f0f6fa}.phone-top{width:64px;height:6px;border-radius:999px;background:#d6e5ee;margin:0 auto 18px}.phone-preview h3{margin:.2rem 0}.phone-preview label{display:block;margin-top:16px;font-weight:700}.fake-input{padding:13px 14px;border:1px solid var(--line);border-radius:14px;background:#fff;color:var(--muted);margin:8px 0 14px}.builder-layout{align-items:start}.builder-layout>aside{display:grid;gap:16px}.empty-state{background:linear-gradient(135deg,#fff,#f8fcff)}
@media(max-width:1100px){.login-shell,.dashboard-grid,.account-grid{grid-template-columns:1fr}.filter-row{grid-template-columns:1fr 1fr}.login-benefits{grid-template-columns:1fr}.result-hero{align-items:flex-start}.live-preview-card{position:static}}
@media(max-width:720px){.login-hero-panel{padding:26px}.login-hero-panel h1{font-size:2.8rem}.filter-row{grid-template-columns:1fr}.result-hero{display:grid}.donut{margin:auto}.timeline-main{display:grid}.security-grid{grid-template-columns:1fr}.dashboard-grid .card{min-height:auto}.mini-survey{display:grid}.hero-panel{border-radius:24px}.survey-card{border-radius:20px}.page-head h1{font-size:2.25rem}.wrap{padding-top:22px}}
@media print{.topbar,.footer,.button-row,.admin-side,.audit-toolbar{display:none!important}.wrap{max-width:none;padding:0}.card,.builder-card{box-shadow:none!important}}

/* UDDE 0.1.1-DEV — polished demo UX */
:root{
  --page-max:1320px;
  --surface-glass:rgba(255,255,255,.78);
  --focus-ring:0 0 0 4px rgba(0,110,182,.16);
  --shadow-deep:0 28px 90px rgba(15,42,68,.12);
}
body:before{content:"";position:fixed;inset:0;pointer-events:none;background:radial-gradient(circle at 18% 0%,rgba(46,125,109,.10),transparent 30%),radial-gradient(circle at 90% 10%,rgba(0,110,182,.09),transparent 32%);z-index:-1}.wrap{max-width:var(--page-max);padding-top:44px}.topbar{min-height:72px;box-shadow:0 8px 30px rgba(15,42,68,.04)}.brand-mark{width:48px;height:48px;border-radius:16px}.main-nav{gap:8px}.main-nav a{padding:10px 14px}.main-nav a.active{box-shadow:inset 0 0 0 1px rgba(0,110,182,.10),0 8px 22px rgba(0,110,182,.08)}.main-nav .user-link{background:#eef7fb}.page-head{align-items:center}.page-head h1{max-width:900px}.card,.module-card,.survey-card,.template-card,.builder-card,.login-card,.hero-panel{border-color:#cfdeea}.premium-hero,.login-hero-panel,.premium-card{box-shadow:var(--shadow-deep)}.btn{transition:.16s ease;box-shadow:0 1px 0 rgba(255,255,255,.45) inset}.btn:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,button:focus-visible{outline:0;box-shadow:var(--focus-ring)}.btn.primary:hover{background:linear-gradient(135deg,#005e9d,#006eb6);transform:translateY(-1px)}.kpi-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin:18px 0}.kpi{background:linear-gradient(135deg,#fff,#f8fcff);border:1px solid var(--line);border-radius:20px;padding:18px;box-shadow:var(--shadow-soft);position:relative;overflow:hidden}.kpi:after{content:"";position:absolute;right:-18px;top:-18px;width:72px;height:72px;background:#e8f3fb;border-radius:999px}.kpi span{display:block;color:var(--muted);font-size:.9rem}.kpi strong{display:block;color:#0064a8;font-size:1.9rem;line-height:1.1;position:relative}.demo-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:22px}.demo-grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.demo-panel{background:var(--surface-glass);border:1px solid var(--line);border-radius:26px;padding:24px;box-shadow:var(--shadow-soft);backdrop-filter:blur(12px)}.demo-panel h2{margin-top:0}.quality-list{display:grid;gap:10px}.quality-item{display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:start;padding:13px;border:1px solid var(--line);border-radius:16px;background:#fff}.quality-item b{width:24px;height:24px;border-radius:999px;display:grid;place-items:center;background:#e7f6ef;color:#17634f}.hero-actions{display:grid;gap:10px;min-width:210px}.hero-actions .btn{width:100%}.survey-card-grid{grid-template-columns:repeat(auto-fit,minmax(430px,1fr));align-items:start}.survey-card{padding:26px;border-radius:26px}.survey-card-head h2{font-size:1.45rem}.survey-card .share-box{background:#f8fcff;border-radius:18px;padding:13px;border:1px solid #dce8f1}.survey-actions{display:flex;flex-wrap:wrap;gap:8px}.survey-actions .btn{margin:0}.progress{background:#e8f0f5;border-radius:999px;height:10px;overflow:hidden}.progress span{height:100%;display:block;background:linear-gradient(90deg,#0078bf,#2b8f83);border-radius:999px}.toolbar-card{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-bottom:18px;background:rgba(255,255,255,.82);border:1px solid var(--line);border-radius:22px;padding:14px 16px;box-shadow:var(--shadow-soft)}.toolbar-card .search{max-width:440px}.builder-steps{position:sticky;top:82px;z-index:10;background:rgba(243,247,251,.72);backdrop-filter:blur(10px);padding:10px;border-radius:22px;border:1px solid rgba(216,227,236,.75)}.builder-step{background:#fff}.builder-step:hover{transform:translateY(-2px);box-shadow:var(--shadow-soft)}.builder-card{border-radius:24px;overflow:hidden}.builder-card-header{background:linear-gradient(135deg,#fbfdff,#f6fbff)}.question-card{border-radius:20px;background:linear-gradient(135deg,#fff,#fbfdff)}.question-number{box-shadow:0 6px 16px rgba(0,110,182,.12)}.live-preview-card{box-shadow:var(--shadow-deep)}.phone-preview{background:linear-gradient(180deg,#fff,#f2f8fb);box-shadow:inset 0 0 0 10px #eef6fb,0 12px 28px rgba(15,42,68,.08)}.admin-shell-title{display:flex;align-items:center;justify-content:space-between;gap:16px;margin:0 0 16px}.admin-shell-title p{margin:0;color:var(--muted)}.admin-side{border-radius:24px}.admin-side a{margin-bottom:4px}.admin-side a.active{box-shadow:inset 4px 0 0 #006eb6}.admin-strip>div{background:#fff;border:1px solid var(--line);border-radius:20px;padding:18px;box-shadow:var(--shadow-soft)}.admin-strip strong{display:block;font-size:1.85rem;color:#0064a8}.admin-strip span{color:var(--muted)}.system-health{display:grid;gap:12px}.health-row{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center;padding:13px;border:1px solid var(--line);border-radius:16px;background:#fff}.health-dot{width:14px;height:14px;border-radius:999px;background:#2e7d6d;box-shadow:0 0 0 5px rgba(46,125,109,.12)}.health-dot.warn{background:#d89a00;box-shadow:0 0 0 5px rgba(216,154,0,.15)}.m365-layout{display:grid;grid-template-columns:1fr 1fr;gap:22px}.m365-guide{background:linear-gradient(135deg,#fff,#f4fbff);border:1px solid var(--line);border-radius:22px;padding:20px}.m365-guide ol{padding-left:1.2rem}.group-card{border-radius:24px}.member-cloud{display:flex;gap:8px;flex-wrap:wrap}.chip{border:1px solid var(--line);background:#f8fcff;border-radius:999px;padding:8px 11px;color:var(--navy);cursor:pointer}.timeline-card{box-shadow:var(--shadow-deep)}.timeline-body{transition:.16s ease}.timeline-body:hover{transform:translateX(2px);border-color:#b8d7e9;background:#fff}.login-shell{grid-template-columns:1.05fr .95fr;max-width:1240px;margin-inline:auto}.m365-login-btn{width:100%;background:linear-gradient(135deg,#0f2a44,#006eb6);color:#fff;border-color:#0f2a44;margin-bottom:12px}.or-divider{display:flex;align-items:center;gap:12px;color:var(--muted);font-size:.9rem;margin:16px 0}.or-divider:before,.or-divider:after{content:"";height:1px;background:var(--line);flex:1}.account-grid{align-items:start}.security-grid div{background:linear-gradient(135deg,#fff,#f8fcff)}.activity-mini{display:grid;gap:10px}.activity-mini div{border:1px solid var(--line);border-radius:16px;padding:12px;background:#fff}.respond-progress{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:20px 0}.respond-progress div{padding:14px;border:1px solid var(--line);border-radius:16px;background:#fbfdff}.public-top{display:flex;justify-content:space-between;align-items:center;gap:18px;margin-bottom:18px}.public-badge{background:#e8f3fb;color:#075a95;border-radius:999px;padding:8px 12px;font-weight:700}.notice{box-shadow:var(--shadow-soft)}
@media(max-width:1200px){.m365-layout,.demo-grid{grid-template-columns:1fr}.survey-card-grid{grid-template-columns:1fr}.builder-steps{position:static}.wrap{padding-inline:22px}}@media(max-width:820px){.kpi-strip,.demo-grid-3{grid-template-columns:1fr 1fr}.toolbar-card{display:grid}.login-shell{grid-template-columns:1fr}.hero-actions{min-width:0}.admin-strip{grid-template-columns:1fr 1fr}.survey-metrics{grid-template-columns:repeat(3,1fr)}}@media(max-width:560px){.kpi-strip,.demo-grid-3,.admin-strip,.survey-metrics{grid-template-columns:1fr}.wrap{padding-inline:16px}.page-head{align-items:flex-start}.hero-panel{padding:22px}.survey-card{padding:20px}.main-nav.open{max-height:calc(100vh - 90px);overflow:auto}.builder-layout{gap:16px}.topbar{min-height:64px}.brand-mark{width:42px;height:42px}.footer{font-size:.8rem}.result-summary{grid-template-columns:1fr!important}.public-top{display:grid}}


/* UDDE 0.1.3-DEV — first-demo polish and spacing unification */
:root{
  --page-max: 1240px;
  --gap-xs: 8px;
  --gap-sm: 12px;
  --gap-md: 16px;
  --gap-lg: 24px;
  --gap-xl: 32px;
  --field-gap: 10px;
  --card-pad: 24px;
  --section-gap: 22px;
  --shadow-demo: 0 18px 48px rgba(15,42,68,.085);
  --shadow-lift: 0 22px 60px rgba(15,42,68,.12);
}
body{background:radial-gradient(circle at 18% 0%,rgba(229,247,245,.85) 0,rgba(243,248,252,.92) 32%,#f7fafe 68%,#f8fbff 100%);}
.wrap{max-width:var(--page-max);padding:42px 30px 34px;}
.page-head{margin:10px 0 var(--gap-xl);align-items:center;}
.page-head p{line-height:1.55;}
.hero-panel,.card,.module-card,.login-card,.builder-card,.template-card,.survey-card,.timeline-card{border-color:#cfdde8;box-shadow:var(--shadow-demo);}
.card,.module-card,.login-card{padding:var(--card-pad);margin-bottom:var(--section-gap);}
.grid2,.grid3,.stats,.admin-strip,.form-grid,.template-grid,.survey-card-grid,.account-grid,.m365-layout,.demo-grid,.demo-grid-3{gap:var(--section-gap);}
.card h2,.builder-card h2,.module-card h2{line-height:1.25;margin-bottom:14px;}
.card p,.module-card p,.template-card p{margin-top:0;}
label{gap:var(--field-gap);margin:0;line-height:1.25;}
label + label{margin-top:0;}
input,select,textarea{min-height:48px;padding:13px 15px;line-height:1.35;}
textarea{min-height:96px;}
.check{display:flex!important;min-height:32px;margin:4px 0;gap:10px;align-items:center;}
.check input{flex:0 0 auto;min-height:auto;}
.btn{min-height:46px;padding:11px 16px;transition:transform .16s ease,box-shadow .16s ease,background .16s ease,border-color .16s ease;}
.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-soft);}
.btn.primary{box-shadow:0 10px 24px rgba(0,110,182,.18);}
.btn.primary:hover{box-shadow:0 16px 34px rgba(0,110,182,.25);}
.button-row{gap:10px;}
.topbar{min-height:70px;padding:12px 28px;}
.main-nav{gap:8px;}
.main-nav a{min-height:42px;display:inline-flex;align-items:center;gap:7px;padding:9px 14px;border:1px solid transparent;}
.main-nav a:hover{background:#f0f7fc;border-color:#d2e6f2;}
.main-nav a.active{background:#e6f2fb;border-color:#cce2f1;box-shadow:inset 0 0 0 1px rgba(255,255,255,.55);}
.brand{min-width:190px;}
.brand-mark{box-shadow:0 12px 28px rgba(0,110,182,.2);}
.footer{max-width:var(--page-max);margin:54px auto 20px;}
/* Cards and dashboard */
.stat-card,.admin-strip>div,.metric{padding:22px;border-radius:22px;}
.stat-card strong,.admin-strip strong{letter-spacing:-.035em;}
.hero-actions{gap:12px;}
.demo-grid .card,.demo-grid-3 .card{margin-bottom:0;}
.admin-strip>div{background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-demo);position:relative;overflow:hidden;}
.admin-strip>div:after{content:"";position:absolute;right:-26px;top:-26px;width:78px;height:78px;border-radius:999px;background:#e8f3fb;}
.admin-strip>div>*{position:relative;}
.admin-strip span{display:block;color:var(--muted);margin-bottom:4px;}
.admin-strip strong{font-size:1.9rem;color:#0064a8;line-height:1.05;}
/* Admin area */
.admin-layout{grid-template-columns:270px minmax(0,1fr);gap:24px;align-items:start;}
.admin-side{top:92px;padding:18px;}
.side-title{margin:0 0 12px;padding:0 8px;}
.admin-side a{padding:13px 12px;margin:2px 0;border:1px solid transparent;}
.admin-side a span{font-weight:700;}
.admin-side a small{display:block;margin-top:2px;line-height:1.25;color:var(--muted);font-weight:500;}
.admin-side a.active,.admin-side a:hover{border-color:#c8e2f2;background:#e8f3fb;}
.admin-content>.card:first-child,.admin-content>.builder-card:first-child{margin-top:0;}
/* Forms: extra breathing room */
.form-grid{align-items:end;}
.form-grid .wide{align-self:stretch;}
.form-grid h2.wide{margin:0 0 4px;align-self:start;}
.form-grid .btn{align-self:end;}
.inline-form.stack{gap:14px;}
.inline-form{gap:10px;}
.admin-note,.info-box,.privacy,.security-strip,.risk-hint{line-height:1.45;}
/* Microsoft 365 page */
.m365-layout{grid-template-columns:minmax(0,1fr) minmax(0,1fr);align-items:start;margin-top:var(--section-gap);}
.m365-layout .card{height:100%;margin:0;}
.m365-guide{margin-bottom:var(--section-gap);}
.group-card{padding:26px;margin-top:var(--section-gap);}
.member-cloud{gap:10px;}
.chip{min-height:38px;}
/* Builder */
.builder-layout{grid-template-columns:minmax(0,1fr) 340px;gap:24px;}
.builder-card{margin-bottom:var(--section-gap);}
.builder-card-header{padding:18px 22px;}
.builder-card-body{padding:22px;}
.builder-steps{gap:12px;margin-bottom:var(--section-gap);}
.builder-step{min-height:70px;}
.question-card{padding:18px;gap:12px;}
.question-actions{gap:8px;}
.live-preview-card{top:94px;}
.phone-preview{margin:14px 0;padding:22px;}
.publish-check{gap:10px;margin-bottom:12px;}
.check-item{min-height:46px;}
/* Survey cards and templates */
.survey-card-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
.survey-card{padding:26px;}
.survey-card .share-box{margin:16px 0;}
.survey-actions{gap:9px;}
.toolbar-card{padding:18px 22px;align-items:center;}
.template-grid{grid-template-columns:repeat(3,minmax(0,1fr));}
.template-card{padding:26px;min-height:300px;}
.template-card .btn{margin-top:auto;}
/* Login and account */
.login-shell{gap:30px;align-items:stretch;padding-top:32px;}
.login-hero-panel,.login-card{border:1px solid #cfdde8;border-radius:30px;box-shadow:var(--shadow-demo);}
.login-card label{margin-top:14px;}
.login-card .btn.big{min-height:52px;}
.login-benefits{gap:14px;}
.account-grid{grid-template-columns:.92fr 1.08fr;align-items:stretch;}
.profile-card,.security-overview{min-height:230px;}
.activity-mini{gap:12px;}
.activity-mini div{padding:14px;}
.password-panel{margin-top:var(--section-gap);}
/* Audit log */
.audit-toolbar{padding:18px 20px;margin-bottom:var(--section-gap);}
.filter-row{gap:14px;}
.timeline-card{padding:24px;}
.timeline-day{margin:14px 0 12px;}
.timeline-body{padding:15px 18px;}
.timeline-main{align-items:flex-start;}
.timeline-main strong{line-height:1.25;}
/* Public respondent */
.survey-public{padding:54px 20px;}
.survey-shell{padding:38px;}
.answer-block{padding:20px;margin:20px 0;}
/* Better empty/readiness states */
.empty-state{padding:40px 28px;}
.kpi-strip{gap:var(--section-gap);}
/* Responsive polish */
@media(max-width:1200px){.wrap{padding-inline:24px}.builder-layout,.m365-layout{grid-template-columns:1fr}.live-preview-card{position:static}.template-grid{grid-template-columns:1fr 1fr}.survey-card-grid{grid-template-columns:1fr}.account-grid{grid-template-columns:1fr}.admin-layout{grid-template-columns:260px minmax(0,1fr)}}
@media(max-width:980px){.admin-layout{grid-template-columns:1fr}.admin-side{position:static}.admin-side{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.side-title{grid-column:1/-1}.admin-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.m365-layout{grid-template-columns:1fr}.page-head{gap:16px}.topbar{min-height:66px}.brand{min-width:0}.main-nav.open{display:grid;grid-template-columns:1fr 1fr;gap:8px}.main-nav.open a{border:1px solid var(--line);}}
@media(max-width:760px){.wrap{padding:28px 16px}.hero-panel{padding:24px;border-radius:24px}.page-head h1{font-size:2.35rem}.page-head p{font-size:1rem}.card,.module-card,.login-card,.builder-card-body,.template-card,.survey-card{padding:20px}.form-grid,.grid2,.grid3,.stats,.admin-strip,.template-grid,.security-grid{grid-template-columns:1fr}.admin-side{grid-template-columns:1fr}.filter-row{grid-template-columns:1fr}.survey-metrics{grid-template-columns:1fr}.builder-step{min-height:60px}.survey-shell{padding:24px;border-radius:24px}.login-shell{padding-top:10px}.login-benefits{grid-template-columns:1fr}.topbar{padding:10px 14px}.main-nav.open{grid-template-columns:1fr}.footer{margin-top:36px}.profile-card,.security-overview{min-height:auto}}
@media(max-width:520px){.page-head{margin-top:0}.page-head h1{font-size:2rem}.hero-actions,.button-row,.survey-actions{width:100%}.hero-actions .btn,.button-row .btn,.survey-actions .btn,.survey-actions a,.survey-actions button{width:100%}.copy-link{display:grid}.admin-strip strong,.stat-card strong{font-size:1.65rem}.builder-steps{grid-template-columns:1fr}.question-card-top{grid-template-columns:1fr}.timeline-main{display:grid}.topbar .brand strong{font-size:.98rem}.brand-mark{width:40px;height:40px}.wrap{padding-top:22px}}

/* UDDE 0.1.3 account mail polish */
.mail-preview{
  white-space:pre-wrap;
  background:linear-gradient(180deg,#f8fbfd,#f4f9fb);
  border:1px solid var(--border);
  border-radius:18px;
  padding:18px 20px;
  color:var(--ink);
  font-size:.95rem;
  line-height:1.65;
  overflow:auto;
}
.notice-card{
  max-width:var(--container);
  margin:0 auto 24px auto;
  padding:18px 22px;
  border:1px solid var(--border);
  border-radius:22px;
  background:#fff8e8;
  color:#6b4a00;
  box-shadow:var(--shadow-soft);
}
.notice-card.warn{border-color:#f5d28b;background:#fff8e8;}

/* UDDE 0.1.4-DEV — branding, media and demo-ready polish */
.brand-logo{width:46px;height:46px;border-radius:14px;background:#fff;border:1px solid var(--line);display:grid;place-items:center;overflow:hidden;box-shadow:0 10px 22px rgba(15,42,68,.10)}
.brand-logo img{width:100%;height:100%;object-fit:contain;padding:4px}.brand-demo{display:flex;gap:18px;align-items:center;padding:18px;border:1px solid var(--line);border-radius:22px;background:linear-gradient(135deg,#fff,#f6fbff)}.brand-demo-logo{width:86px;height:86px;border-radius:24px;background:linear-gradient(145deg,var(--blue),#2e7d6d);display:grid;place-items:center;color:#fff;font-size:2rem;font-weight:700;overflow:hidden;box-shadow:var(--shadow-soft)}.brand-demo-logo img{width:100%;height:100%;object-fit:contain;background:#fff;padding:8px}.brand-demo h3{margin:0;color:var(--navy);font-size:1.55rem}.brand-demo p{margin:.25rem 0;color:var(--muted)}.brand-demo small{color:var(--green);font-weight:700;text-transform:uppercase;letter-spacing:.12em}.hero-image-preview{margin-top:18px;border:1px solid var(--line);border-radius:24px;overflow:hidden;background:#f6fbff}.hero-image-preview img{display:block;width:100%;height:220px;object-fit:cover}.hero-image-preview.compact img{height:150px}.spacious-form{row-gap:22px;column-gap:24px}.spacious-form small{font-weight:500;line-height:1.35}.quality-list{display:grid;gap:12px}.quality-list>div{padding:14px 16px;border:1px solid var(--line);border-radius:16px;background:#f8fbfd}.quality-list strong{display:block;color:var(--navy)}.quality-list span{display:block;color:var(--muted);margin-top:3px}.public-premium{position:relative;overflow:hidden}.public-hero-image{margin:-38px -38px 28px;border-radius:0 0 28px 28px;overflow:hidden;max-height:280px;background:#e8f3fb}.public-hero-image img{display:block;width:100%;height:280px;object-fit:cover}.public-logo{width:auto;max-width:var(--brand-form-logo-size,96px);max-height:calc(var(--brand-form-logo-size,96px) * .75);object-fit:contain;margin:0 0 18px;display:block}.answer-block legend{padding-right:12px}.answer-block input,.answer-block select,.answer-block textarea{margin-top:8px}.choice{padding:12px 14px!important;border:1px solid var(--line);border-radius:14px;background:#fbfdff;margin:8px 0;transition:.15s ease}.choice:hover{border-color:#b8d9ee;background:#f2f8fd}.choice input{min-height:auto;margin-right:8px}.scale{gap:10px;flex-wrap:wrap}.scale label span{min-width:42px;height:42px;border-radius:13px}.section-title{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px}.admin-side a{transition:background .15s ease,border-color .15s ease,transform .15s ease}.admin-side a:hover{transform:translateX(2px)}.module-card,.survey-card,.template-card,.card{transition:box-shadow .16s ease,border-color .16s ease,transform .16s ease}.survey-card:hover,.template-card:hover,.module-card:hover{transform:translateY(-2px)}.form-grid input[type=file]{padding:11px;background:#fbfdff}.form-grid input[type=color]{padding:6px;min-height:48px}.builder-card-body .hero-image-preview{margin-bottom:8px}.public-top{margin-bottom:18px}.thanks{max-width:760px;margin:70px auto;background:#fff;border:1px solid var(--line);border-radius:30px;padding:42px;box-shadow:var(--shadow);text-align:center}.thanks h1{color:var(--navy);font-size:2.4rem;margin-top:0}.thanks p{color:var(--muted);font-size:1.1rem}@media(max-width:760px){.brand-demo{align-items:flex-start}.brand-demo-logo{width:68px;height:68px}.public-hero-image{margin:-24px -24px 22px}.public-hero-image img{height:190px}.public-logo{max-width:150px}.hero-image-preview img{height:160px}.section-title{display:grid}.spacious-form{gap:18px}}


/* UDDE 0.1.5-DEV — demo-ready brand polish */
.topbar .brand{gap:14px;min-height:52px;}
.topbar .brand-logo{width:var(--brand-gui-logo-size,46px);height:var(--brand-gui-logo-size,46px);max-width:84px;max-height:84px;min-width:34px;min-height:34px;border-radius:14px;flex:0 0 auto;background:#fff;border:1px solid var(--line);display:grid;place-items:center;overflow:hidden;box-shadow:0 8px 18px rgba(15,42,68,.08)}
.topbar .brand-logo img{display:block;width:100%;height:100%;max-width:100%;max-height:100%;object-fit:contain;padding:4px;}
.brand-demo-logo{width:var(--brand-form-logo-size,96px);height:var(--brand-form-logo-size,96px);min-width:68px;min-height:68px;max-width:190px;max-height:190px;}
.brand-demo-logo img{display:block;width:100%;height:100%;object-fit:contain;background:#fff;padding:8px;}
.admin-side a.active{box-shadow:inset 3px 0 0 var(--blue);}
.recommendation-list{display:grid;gap:12px;margin-top:12px;}
.recommendation-list>div{display:grid;grid-template-columns:160px minmax(0,1fr);gap:12px;align-items:start;padding:14px 16px;border:1px solid var(--line);border-radius:16px;background:#f8fbfd;}
.recommendation-list strong{color:var(--navy);line-height:1.35;}
.recommendation-list p{margin:0;color:var(--muted);line-height:1.55;}
.form-grid label small{display:block;margin-top:2px;margin-bottom:4px;}
.brand-preview .section-title{margin-bottom:16px;}
@media(max-width:760px){.topbar .brand-logo{width:min(var(--brand-gui-logo-size,46px),52px);height:min(var(--brand-gui-logo-size,46px),52px)}.recommendation-list>div{grid-template-columns:1fr;gap:4px}.brand-demo-logo{width:68px;height:68px}}

/* 0.1.6 separate logo sizing */
.logo-size-preview{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:12px}.logo-size-preview .mini-preview{border:1px solid var(--line);border-radius:18px;padding:14px;background:#fbfdff}.logo-size-preview strong{display:block;margin-bottom:8px;color:var(--navy)}.logo-size-preview .topbar-sim{height:54px;display:flex;align-items:center;gap:12px}.logo-size-preview .form-sim{min-height:130px;display:grid;place-items:center}.recommendation-list p{margin:4px 0 0;line-height:1.45}.topbar .brand-logo{width:var(--brand-gui-logo-size,46px)!important;height:var(--brand-gui-logo-size,46px)!important}.brand-demo-logo{width:var(--brand-form-logo-size,96px)!important;height:var(--brand-form-logo-size,96px)!important}
@media(max-width:760px){.logo-size-preview{grid-template-columns:1fr}.brand-demo-logo{width:min(var(--brand-form-logo-size,96px),120px)!important;height:min(var(--brand-form-logo-size,96px),120px)!important}}
@media(max-width:760px){.public-logo{max-width:min(var(--brand-form-logo-size,96px),150px)!important;max-height:120px!important}}


/* UDDE 0.1.8-DEV — lifecycle, sharing and print report polish */
.lifecycle-toolbar{grid-template-columns:minmax(0,1fr) auto minmax(240px,360px);align-items:center;gap:18px}.lifecycle-card{position:relative}.danger-zone{margin-top:18px;border:1px solid #f0d0d0;border-radius:18px;background:#fffafa;overflow:hidden}.danger-zone summary{cursor:pointer;padding:14px 16px;color:#823333;font-weight:650}.lifecycle-actions{display:grid;gap:12px;padding:0 16px 16px}.delete-confirm-form{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:end;padding:14px;border:1px dashed #e5adad;border-radius:16px;background:#fff}.btn.danger{border-color:#d65b5b;background:#fff;color:#8a1f1f}.btn.danger:hover{background:#fff1f1}.lifecycle-panel .button-row.stack{display:grid;grid-template-columns:1fr;gap:10px}.share-panel textarea[readonly],.share-panel input[readonly]{background:#f8fbfd}.qr-card{display:flex;gap:16px;align-items:center;margin-top:18px;padding:16px;border:1px solid var(--line);border-radius:18px;background:linear-gradient(135deg,#fff,#f7fbff)}.qr-fake{width:86px;height:86px;flex:0 0 auto;background:#fff;border:1px solid var(--line);border-radius:12px;display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:10px;box-shadow:var(--shadow-soft)}.qr-fake span{background:repeating-linear-gradient(45deg,#0f2a44 0 5px,#fff 5px 10px);border-radius:6px}.premium-thanks .empty-icon{margin:0 auto 16px;background:#e8f8ef;color:#1f7a45;border-color:#bfe8d0}.report-page{max-width:1000px;margin:0 auto;display:grid;gap:22px}.report-cover{padding:42px}.report-brand{display:flex;gap:14px;align-items:center;margin-bottom:26px}.report-brand img{width:70px;height:70px;object-fit:contain;border:1px solid var(--line);border-radius:18px;background:#fff;padding:6px}.report-brand strong{display:block;color:var(--navy);font-size:1.15rem}.report-brand small{display:block;color:var(--muted)}.report-cover h1{font-size:2.8rem;color:var(--navy);margin:.25rem 0 1rem}.report-question{break-inside:avoid}.no-print{margin-top:24px}
@media(max-width:900px){.lifecycle-toolbar{grid-template-columns:1fr}.delete-confirm-form{grid-template-columns:1fr}.qr-card{align-items:flex-start}.report-cover{padding:28px}.report-cover h1{font-size:2.1rem}}
@media print{body{background:#fff}.topbar,.footer,.no-print,.notice{display:none!important}.wrap{max-width:none;padding:0}.card{box-shadow:none!important;border-color:#d9e2ea;break-inside:avoid}.report-page{max-width:none;gap:14px}.report-cover h1{font-size:30pt}.btn{display:none!important}.chart-track span{print-color-adjust:exact;-webkit-print-color-adjust:exact}}

/* UDDE 0.1.8-DEV — clearer copy-as-draft, real QR preview and demo polish */
.copy-info{display:grid;gap:4px;border:1px solid var(--line);border-radius:16px;background:linear-gradient(135deg,#fbfdff,#f4f9fd);padding:12px 14px;margin-top:12px}
.copy-info strong{color:var(--navy);font-size:.95rem}.copy-info span,.copy-note{display:block;color:var(--muted);font-size:.82rem;line-height:1.35;margin-top:4px}.survey-actions form{align-content:start}.real-qr-card{align-items:center}.qr-image{width:132px;height:132px;object-fit:contain;border:1px solid var(--line);border-radius:16px;background:#fff;padding:8px;box-shadow:var(--shadow-soft)}.share-panel .btn + label,.share-panel label + .btn{margin-top:-4px}.share-panel textarea{font-family:inherit;line-height:1.5}.premium-thanks{max-width:760px;margin:50px auto;text-align:center}.premium-thanks h1{font-size:clamp(2rem,5vw,3.2rem)}.premium-thanks p{font-size:1.08rem;line-height:1.65;max-width:620px;margin-inline:auto}.chart-list{display:grid;gap:14px}.chart-row{padding:12px;border:1px solid var(--line);border-radius:16px;background:#fff}.chart-label{display:flex;justify-content:space-between;gap:16px;align-items:baseline;margin-bottom:10px}.chart-label small{color:var(--muted);white-space:nowrap}.chart-track{height:12px;border-radius:999px;background:#edf4f8;overflow:hidden}.chart-track span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--accent),#34a6d8)}
@media(max-width:620px){.real-qr-card{display:grid}.qr-image{width:160px;height:160px}.chart-label{display:grid;gap:4px}.chart-label small{white-space:normal}}

/* UDDE 0.1.9-DEV — WCAG polish without changing the visual design */
:root{--focus:#ffbf47;--focus-ring:0 0 0 4px rgba(255,191,71,.55)}
.skip-link{position:absolute;left:18px;top:-80px;z-index:1000;background:#fff;color:#0f2a44;border:2px solid var(--focus);border-radius:12px;padding:10px 14px;font-weight:650;box-shadow:var(--shadow)}
.skip-link:focus,.skip-link:focus-visible{top:14px;outline:none;box-shadow:var(--focus-ring),var(--shadow)}
:focus{outline:none}
:focus-visible{outline:3px solid var(--focus);outline-offset:3px;box-shadow:var(--focus-ring)}
a:focus-visible,.btn:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,.link-button:focus-visible,summary:focus-visible{outline:3px solid var(--focus);outline-offset:3px;box-shadow:var(--focus-ring)}
.main-nav a[aria-current="page"],.admin-side a[aria-current="page"]{position:relative}
.main-nav a[aria-current="page"]:after{content:"";position:absolute;left:16px;right:16px;bottom:5px;height:2px;border-radius:999px;background:currentColor;opacity:.55}
.admin-side a[aria-current="page"]:before{content:"";position:absolute;left:0;top:10px;bottom:10px;width:4px;border-radius:0 999px 999px 0;background:var(--blue)}
.admin-side a{position:relative}
label span,.field-label{display:block;line-height:1.35}
label small,.help-text,.form-help{display:block;color:var(--muted);font-weight:400;line-height:1.45;margin-top:3px}
input,select,textarea{min-height:46px}
textarea{min-height:112px}
button,input,select,textarea{touch-action:manipulation}
.check,.choice{min-height:42px;align-items:flex-start}
.check input,.choice input{margin-top:.35em;min-height:auto;flex:0 0 auto}
.scale span{min-width:44px;min-height:44px}
.notice[role="status"],.notice[role="alert"]{font-weight:500}
.pill{border:1px solid rgba(15,42,68,.06)}
.pill.ok,.pill.green{border-color:#a8d8c7}.pill.blue{border-color:#bddcf0}.pill.purple{border-color:#d4caf4}.pill.warn{border-color:#ead08a}.pill.dark{border-color:#ccd4dd}
.udde-toast{position:fixed;left:50%;bottom:24px;transform:translate(-50%,20px);z-index:2000;background:#0f2a44;color:#fff;border-radius:999px;padding:12px 18px;box-shadow:var(--shadow);opacity:0;pointer-events:none;transition:opacity .18s ease,transform .18s ease;font-weight:600}
.udde-toast.show{opacity:1;transform:translate(-50%,0)}
.sr-only{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important}
.table-scroll:focus-visible{outline:3px solid var(--focus);outline-offset:3px;box-shadow:var(--focus-ring)}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}.module-card:hover{transform:none}}
@media(max-width:720px){.btn,.main-nav a,.admin-side a{min-height:46px}.button-row{gap:12px}.form-grid{gap:20px}label{gap:8px}.udde-toast{left:16px;right:16px;transform:translateY(20px);text-align:center}.udde-toast.show{transform:translateY(0)}}

/* UDDE 0.1.10-DEV — WCAG refinement without visible skip link */
/* The visual skip link is removed from markup. Keep strong, elegant focus states. */
:where(a, button, input, select, textarea, summary, [tabindex]):focus-visible{
  outline: 3px solid rgba(0,110,182,.55);
  outline-offset: 3px;
  box-shadow: 0 0 0 6px rgba(0,110,182,.14);
}
.main-nav a:focus-visible,
.admin-side a:focus-visible,
.btn:focus-visible{
  text-decoration:none;
  border-color:#7bbce3;
}
input::placeholder, textarea::placeholder{color:#5f7082;opacity:1;}
.pill{line-height:1.25;}
.empty-state{color:var(--ink);}
@media (forced-colors: active){
  .btn,.card,.module-card,.login-card,.stat-card,.admin-side,.survey-shell{border:1px solid CanvasText;}
  :where(a,button,input,select,textarea):focus-visible{outline:3px solid Highlight;box-shadow:none;}
}

/* UDDE 0.1.11-DEV: bildhantering och upload-polish */
.upload-guidance{display:grid;gap:10px;margin-top:10px;padding:12px 14px;border:1px dashed var(--line);border-radius:16px;background:#f8fbfd;color:var(--muted);font-size:.92rem}.upload-guidance strong{color:var(--navy)}.small-note{font-size:.92rem;margin-top:12px}.hero-position-preview{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:10px}.hero-position-preview span{border:1px solid var(--line);border-radius:14px;padding:10px;text-align:center;background:#fbfdff;color:var(--muted);font-weight:700}.form-grid input[type=file]::file-selector-button{border:1px solid #c9dce8;background:#f2f8fd;border-radius:10px;padding:8px 12px;color:var(--navy);font-weight:700}.form-grid input[type=file]::file-selector-button:hover{background:#e6f2fb}.hero-image-preview img,.public-hero-image img{object-position:center center}.hero-image-preview img[style],.public-hero-image img[style]{object-position:inherit}

/* UDDE 0.1.12 media upload polish */
.file-upload{display:block;width:100%}
.file-upload-label{display:block;font-weight:700;color:var(--ink);margin-bottom:.35rem}
.file-upload-help{margin:.15rem 0 .65rem;color:var(--muted);font-size:.95rem;line-height:1.45}
.file-upload-control{position:relative;display:flex;align-items:center;gap:.75rem;min-height:3.1rem;padding:.55rem .7rem;border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.88)}
.file-upload-control:hover{border-color:rgba(0,110,182,.45);box-shadow:0 8px 24px rgba(0,110,182,.08)}
.file-upload-control input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.file-upload-control .btn{pointer-events:none;white-space:nowrap}
.file-name{color:var(--muted);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.image-library{margin-top:.5rem;padding:1rem;border:1px solid var(--line);border-radius:18px;background:linear-gradient(180deg,rgba(255,255,255,.86),rgba(250,253,255,.86))}
.section-title.compact{margin-bottom:.75rem}
.section-title.compact h3{margin:0 0 .15rem;font-size:1.05rem}
.image-library-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.8rem;max-height:360px;overflow:auto;padding:.15rem .15rem .25rem}
.image-choice{display:grid;gap:.55rem;padding:.55rem;border:1px solid var(--line);border-radius:16px;background:#fff;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}
.image-choice:hover{transform:translateY(-1px);box-shadow:0 12px 30px rgba(17,38,62,.08);border-color:rgba(0,110,182,.35)}
.image-choice.selected,.image-choice:has(input:checked){border-color:var(--blue);box-shadow:0 0 0 3px rgba(0,110,182,.12)}
.image-choice input{position:absolute;opacity:0;pointer-events:none}
.image-choice .thumb{display:block;height:82px;border-radius:12px;overflow:hidden;background:#eef6fb;border:1px solid rgba(0,0,0,.04)}
.image-choice .thumb img{width:100%;height:100%;object-fit:cover;display:block}
.image-meta{display:grid;gap:.15rem;min-width:0}
.image-meta strong{font-size:.88rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.image-meta small{font-size:.76rem;color:var(--muted);line-height:1.25}
.empty-mini{padding:1rem;border:1px dashed var(--line);border-radius:14px;color:var(--muted);background:rgba(255,255,255,.55)}
.clear-library-choice{margin-top:.85rem}
@media(max-width:720px){.image-library-grid{grid-template-columns:repeat(2,minmax(0,1fr));max-height:none}.file-upload-control{align-items:flex-start;flex-direction:column}.file-name{white-space:normal}}

/* UDDE 0.1.13 media library UX fix */
.media-picker{margin-top:1rem;padding:1rem;border:1px solid var(--line);border-radius:22px;background:linear-gradient(180deg,rgba(255,255,255,.92),rgba(250,253,255,.88));box-shadow:0 12px 28px rgba(17,38,62,.04)}
.media-picker .section-title.compact{align-items:flex-start;margin-bottom:1rem}
.media-current{display:flex;align-items:center;gap:.85rem;margin-bottom:1rem;padding:.75rem;border:1px solid rgba(0,110,182,.18);border-radius:16px;background:rgba(233,246,255,.65)}
.media-current-thumb{width:92px;height:52px;flex:0 0 92px;border-radius:12px;overflow:hidden;border:1px solid var(--line);background:#eef6fb}
.media-current-thumb img{width:100%;height:100%;display:block;object-fit:cover}
.media-current strong,.media-current small{display:block}.media-current small{color:var(--muted);margin-top:.15rem}
.media-library-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem;max-height:430px;overflow:auto;padding:.15rem .25rem .4rem;contain:layout paint}
.media-tile{position:relative;display:grid;gap:.65rem;min-width:0;padding:.65rem;border:1px solid var(--line);border-radius:18px;background:#fff;cursor:pointer;transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease, background .15s ease;overflow:hidden}
.media-tile:hover{transform:translateY(-2px);box-shadow:0 16px 34px rgba(17,38,62,.10);border-color:rgba(0,110,182,.38)}
.media-tile.selected,.media-tile:has(input:checked){border-color:var(--blue);background:linear-gradient(180deg,#fff,rgba(237,248,255,.95));box-shadow:0 0 0 3px rgba(0,110,182,.13),0 16px 34px rgba(17,38,62,.09)}
.media-tile input{position:absolute;opacity:0;pointer-events:none}
.media-thumb{display:block;width:100%;aspect-ratio:16/9;border-radius:14px;overflow:hidden;background:#eef6fb;border:1px solid rgba(0,0,0,.05)}
.media-thumb img{width:100%!important;height:100%!important;max-width:none!important;max-height:none!important;display:block!important;object-fit:cover!important;object-position:center center}
.media-info{display:grid;gap:.2rem;min-width:0}.media-info strong{font-size:.9rem;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.media-info small{font-size:.78rem;line-height:1.3;color:var(--muted)}
.media-action{display:inline-flex;align-items:center;justify-content:center;min-height:2.15rem;padding:.45rem .6rem;border:1px solid var(--line);border-radius:12px;background:#f7fbff;color:var(--blue);font-weight:800;font-size:.82rem;text-align:center}
.media-tile.selected .media-action,.media-tile:has(input:checked) .media-action{background:var(--blue);color:#fff;border-color:var(--blue)}
.media-picker .clear-library-choice{margin-top:1rem;padding:.7rem .8rem;border:1px dashed var(--line);border-radius:14px;background:rgba(255,255,255,.62)}
@media(max-width:980px){.media-library-grid{grid-template-columns:repeat(auto-fill,minmax(145px,1fr));max-height:none}.media-current{align-items:flex-start}.media-current-thumb{width:82px;height:48px;flex-basis:82px}}
@media(max-width:560px){.media-library-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem}.media-picker{padding:.8rem}.media-action{font-size:.76rem}.media-info strong{font-size:.82rem}.media-info small{font-size:.72rem}.media-current{display:grid}.media-current-thumb{width:100%;height:auto;aspect-ratio:16/9}}

/* UDDE 0.1.15-DEV — test-ready publiceringsguide, systemkontroll, behörighetstest och mobilpolish */
.publish-layout{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(280px,.65fr);gap:var(--section-gap);align-items:stretch;margin-bottom:var(--section-gap)}
.publish-score,.publish-actions,.system-score{display:flex;justify-content:space-between;gap:22px;align-items:center}
.publish-actions{display:grid;align-content:start}
.publish-actions form{margin:0}
.checklist-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.check-card{display:grid;grid-template-columns:auto minmax(0,1fr);gap:12px;padding:16px;border:1px solid var(--line);border-radius:18px;background:linear-gradient(135deg,#fff,#f8fcff)}
.check-card.ok{border-color:#bee6d2;background:linear-gradient(135deg,#fbfffd,#f0fbf6)}
.check-card.warn{border-color:#f3d38a;background:linear-gradient(135deg,#fff,#fff9ea)}
.check-badge{width:30px;height:30px;border-radius:999px;display:grid;place-items:center;font-weight:800;background:#e8f3fb;color:#006eb6;border:1px solid #cfe4f2}
.check-card.ok .check-badge{background:#e8f8ef;color:#17634f;border-color:#bee6d2}
.check-card.warn .check-badge{background:#fff2ca;color:#7a5600;border-color:#f3d38a}
.check-card strong{display:block;color:var(--navy);font-size:1rem;margin-bottom:4px}
.check-card p{margin:0 0 4px;line-height:1.45;color:var(--muted)}
.share-box{display:grid;gap:10px}.share-box code{display:block;white-space:normal;word-break:break-all;background:#f7fbfe;border:1px solid var(--line);border-radius:14px;padding:12px;color:#18324b}
.system-check-list{display:grid;gap:10px}
.system-check{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:12px;align-items:center;padding:14px 16px;border:1px solid var(--line);border-radius:18px;background:#fff}
.system-check.ok{background:linear-gradient(135deg,#fff,#f7fffb)}.system-check.warn{background:linear-gradient(135deg,#fff,#fff8eb)}
.system-check small{display:block;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:.72rem}.system-check strong{display:block;color:var(--navy)}.check-value{font-weight:750;color:var(--navy);text-align:right;max-width:360px;overflow-wrap:anywhere}
.permission-filter{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px;align-items:end}.permission-stats{margin-bottom:var(--section-gap)}
.table-card table{width:100%}.table-card th,.table-card td{vertical-align:top}
.button-row.stack{display:grid;grid-template-columns:1fr;gap:10px}.button-row.stack .btn{width:100%}
@media(max-width:980px){.publish-layout,.checklist-grid{grid-template-columns:1fr}.publish-score,.system-score{align-items:flex-start}.permission-filter{grid-template-columns:1fr}.system-check{grid-template-columns:auto minmax(0,1fr);}.check-value{grid-column:2;text-align:left}.admin-content .stats.permission-stats{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:760px){.publish-score,.system-score{display:grid}.donut{margin:auto}.check-card{padding:14px}.system-check{padding:13px}.table-card{overflow:auto}.table-card table{min-width:680px}.admin-content .stats.permission-stats{grid-template-columns:1fr}.builder-steps{display:grid;grid-template-columns:1fr 1fr}.builder-step{min-width:0}.sticky-mobile-actions{position:sticky;bottom:10px;z-index:20;background:rgba(247,250,254,.86);backdrop-filter:blur(12px);padding:10px;border:1px solid rgba(207,221,232,.8);border-radius:18px;box-shadow:var(--shadow-soft)}}
@media(max-width:520px){.builder-steps{grid-template-columns:1fr}.page-head .button-row{display:grid;grid-template-columns:1fr}.page-head .button-row .btn{width:100%}.publish-actions .btn{min-height:48px}.checklist-grid{gap:10px}.clean-list li{display:grid;gap:4px}.survey-card-grid{gap:16px}.survey-card .survey-actions{display:grid;grid-template-columns:1fr}.survey-card .survey-actions .btn,.survey-card .survey-actions form,.survey-card .survey-actions button{width:100%}.system-check{grid-template-columns:1fr}.system-check .health-dot{display:none}.check-value{grid-column:auto}.admin-side a{min-height:64px}.respond-progress{grid-template-columns:1fr}.public-hero-image{max-height:260px}}
/* UDDE 0.1.17-DEV — metric cards and role-aware polish */
.stat-card,.kpi,.metric,.admin-strip>div{isolation:isolate;overflow:hidden;}
.stat-card:after,.kpi:after,.metric:after,.admin-strip>div:after{z-index:0;pointer-events:none;opacity:.58;right:-42px;top:-42px;}
.stat-card>*,.kpi>*,.metric>*,.admin-strip>div>*{position:relative;z-index:1;}
.stat-card strong,.kpi strong,.metric strong,.admin-strip strong{max-width:calc(100% - 34px);overflow-wrap:anywhere;}
.kpi{padding-right:76px;}
@media(max-width:760px){.kpi{padding-right:58px}.stat-card:after,.kpi:after,.metric:after,.admin-strip>div:after{right:-54px;top:-54px;opacity:.45}}

/* UDDE 0.1.17-DEV — layout stability and demo polish */
:root{--content-gap:24px;--card-inner-gap:18px;}
.card,.module-card,.template-card,.survey-card,.login-card{min-width:0;}
.admin-layout{align-items:start;}
.admin-layout>*,.builder-layout>*,.m365-layout>*{min-width:0;}
.admin-side{max-width:100%;}
.table-card{overflow-x:auto;overflow-y:hidden;}
.table-card table{min-width:900px;}
.table-card th,.table-card td{word-break:normal;overflow-wrap:break-word;}
.mail-preview{max-height:420px;overflow:auto;}

/* Template cards must never compress category words vertically */
.template-grid{align-items:stretch;}
.template-card{display:flex;flex-direction:column;gap:20px;min-width:0;overflow:hidden;}
.template-card>div:first-child{min-width:0;}
.template-card h2,.template-card p{overflow-wrap:break-word;}
.template-card .survey-metrics{display:grid;grid-template-columns:repeat(2,minmax(128px,1fr));gap:12px;margin-top:auto;}
.template-card .metric{min-width:0;padding:16px;border-radius:18px;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;}
.template-card .metric strong{font-size:1.25rem;line-height:1.2;max-width:none!important;overflow-wrap:normal!important;word-break:normal!important;hyphens:none;}
.template-card .metric span{white-space:normal;}
.template-card .btn{align-self:flex-start;}

/* Admin user page polish */
.form-grid.card{align-items:start;}
.form-grid.card label{min-width:0;}
.form-grid.card .wide{min-width:0;}
.admin-layout .card + .card{margin-top:22px;}

/* KPI cards: keep decorative circles behind content only */
.stat-card,.metric,.admin-strip>div{position:relative;overflow:hidden;isolation:isolate;}
.stat-card:after,.metric:after,.admin-strip>div:after{z-index:0;pointer-events:none;opacity:.35;right:-58px;top:-58px;}
.stat-card>*,.metric>*,.admin-strip>div>*{position:relative;z-index:1;}
.stat-card strong,.metric strong,.admin-strip strong{max-width:100%;overflow-wrap:normal;word-break:normal;}

/* Top navigation consistency */
.main-nav a{display:inline-flex;align-items:center;justify-content:center;min-height:42px;line-height:1.1;}
.main-nav a.active,.main-nav a[aria-current="page"]{box-shadow:inset 0 -2px 0 rgba(0,94,168,.16);}

/* Empty states and forms need predictable spacing */
.empty-state{min-height:170px;display:grid;place-items:center;gap:8px;}
.card .form-grid,.builder-card-body .form-grid{gap:20px 22px;}
label small,.muted small{line-height:1.45;}

@media(max-width:1200px){
  .template-card .survey-metrics{grid-template-columns:repeat(2,minmax(110px,1fr));}
}
@media(max-width:760px){
  .template-card .survey-metrics{grid-template-columns:1fr 1fr;}
  .template-card .metric{min-height:86px;}
  .template-card .metric strong{font-size:1.15rem;}
  .table-card table{min-width:760px;}
}
@media(max-width:480px){
  .template-card .survey-metrics{grid-template-columns:1fr;}
  .template-card .btn{width:100%;}
}

/* UDDE 0.1.18-DEV – Feedbackmodul */
.feedback-page-head .hero-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.stat-chip{display:grid;gap:2px;min-width:96px;padding:14px 18px;border:1px solid var(--border,#cfe1ee);border-radius:18px;background:rgba(255,255,255,.78);box-shadow:var(--shadow-soft,0 16px 40px rgba(15,49,78,.08))}.stat-chip strong{font-size:30px;line-height:1;color:var(--blue,#006eb6)}.stat-chip span{font-size:13px;color:var(--muted,#60728a);font-weight:700}.stat-chip.warn strong{color:#a56a00}.feedback-grid{display:grid;grid-template-columns:minmax(320px,420px) minmax(0,1fr);gap:24px;align-items:start}.form-stack{display:grid;gap:18px}.form-grid.compact{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.feedback-form-card textarea{min-height:160px}.help-text{margin:0;color:var(--muted,#60728a);font-size:14px;line-height:1.5}.feedback-list-card{min-width:0}.feedback-list{display:grid;gap:14px}.feedback-item{border:1px solid var(--border,#cfe1ee);border-radius:18px;background:rgba(255,255,255,.82);overflow:hidden}.feedback-item summary{cursor:pointer;list-style:none;display:grid;gap:8px;padding:18px 20px;transition:background .16s ease}.feedback-item summary::-webkit-details-marker{display:none}.feedback-item summary:hover{background:#f7fbff}.feedback-item[open] summary{border-bottom:1px solid var(--border,#cfe1ee);background:#f7fbff}.feedback-badges{display:flex;gap:7px;align-items:center;flex-wrap:wrap}.feedback-item summary strong{font-size:18px;color:var(--ink,#102a43);line-height:1.25}.feedback-item summary small{color:var(--muted,#60728a);font-weight:650;line-height:1.45}.feedback-detail{display:grid;grid-template-columns:minmax(0,1fr) minmax(280px,360px);gap:20px;padding:20px}.feedback-detail h3{margin:0 0 8px;font-size:16px}.feedback-text,.feedback-note{border:1px solid var(--border,#cfe1ee);border-radius:16px;padding:16px;background:#fbfdff;line-height:1.6;white-space:normal}.feedback-note{background:#effaf5;border-color:#bfead4}.feedback-admin-form{display:grid;gap:14px;padding:16px;border:1px solid var(--border,#cfe1ee);border-radius:18px;background:#fff}.feedback-admin-form textarea{min-height:140px}@media (max-width:980px){.feedback-grid{grid-template-columns:1fr}.feedback-detail{grid-template-columns:1fr}.form-grid.compact{grid-template-columns:1fr}.stat-chip{min-width:0}}

/* UDDE 0.1.25-DEV – Auditlogg export och lättare GUI */
.audit-toolbar-modern { display: grid; gap: 1.25rem; }
.audit-summary { display: flex; align-items: flex-start; justify-content: space-between; gap: 1rem; }
.audit-summary h2 { margin: .2rem 0 .25rem; }
.audit-summary p { max-width: 62ch; margin: 0; color: var(--muted); }
.audit-export-actions { flex-wrap: wrap; justify-content: flex-end; }
@media (max-width: 760px) {
  .audit-summary { display: grid; }
  .audit-export-actions { justify-content: stretch; }
  .audit-export-actions .btn { width: 100%; justify-content: center; }
}

/* UDDE 0.1.22 polish */
.card,.panel,.stat-card{overflow:hidden}
.grid,.cards{align-items:stretch}
input,select,textarea{min-height:44px}
.menu .active,.sidebar .active{position:relative}
.menu .active::before,.sidebar .active::before{content:"";position:absolute;left:0;top:10%;height:80%;width:4px;background:var(--blue);border-radius:8px}
.image-library img{object-fit:cover;max-width:100%;aspect-ratio:16/9}

/* UDDE 0.1.25 – enkätlogik, publiceringspolish och stabilare demo-UX */
.rule-summary{margin:.55rem 0 0;color:var(--muted);font-size:.95rem;line-height:1.45}
.rule-box{margin-top:1rem;border:1px solid var(--line);border-radius:18px;background:linear-gradient(180deg,#fbfdff,#f6fbff);padding:.2rem .85rem;overflow:hidden}
.rule-box summary{cursor:pointer;font-weight:750;color:var(--ink);padding:.85rem .15rem;list-style:none}
.rule-box summary::-webkit-details-marker{display:none}
.rule-box summary:before{content:'↳';display:inline-grid;place-items:center;width:1.7rem;height:1.7rem;border-radius:999px;background:#e8f5ff;color:var(--brand);margin-right:.55rem;font-weight:900}
.rule-box[open]{box-shadow:0 12px 32px rgba(15,55,90,.08)}
.rule-box .form-grid{padding:.35rem 0 1rem;align-items:end}
.answer-block[hidden]{display:none!important}
.respond-progressbar{margin:1rem 0 1.1rem;height:.58rem;background:#e8f0f6;border-radius:999px;overflow:hidden;border:1px solid rgba(0,90,145,.10)}
.respond-progressbar span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--brand),#2c9c92);border-radius:999px;transition:width .25s ease}
.thanks-logo{max-width:var(--form-logo-size,120px);max-height:160px;object-fit:contain;margin:0 auto 1rem;display:block}
.question-card{transition:box-shadow .18s ease, transform .18s ease, border-color .18s ease}
.question-card:focus-within,.question-card:hover{border-color:#b7d8ef;box-shadow:0 18px 50px rgba(13,74,116,.10);transform:translateY(-1px)}
.mini-checks .mini-check{align-items:flex-start}.mini-checks .mini-check span{flex:0 0 auto}
@media(max-width:760px){.rule-box .form-grid{grid-template-columns:1fr}.question-actions{flex-wrap:wrap}.respond-progress{grid-template-columns:1fr}.public-premium{padding:1.2rem}.survey-public{padding-inline:1rem}}

/* UDDE 0.1.25-DEV – säkrare publiceringspanel och varningsvisning */
.side-card .mini-checks,
.publish-checklist .checklist-grid {
  min-width: 0;
}
.side-card .mini-check,
.check-card {
  overflow-wrap: anywhere;
}
.side-card .progress + .muted {
  margin-top: .7rem;
  line-height: 1.45;
}


/* UDDE 0.1.27-DEV — collapsible sections to keep long pages calm and demo-friendly */
details.ux-accordion{overflow:hidden}
details.ux-accordion>summary{list-style:none;cursor:pointer;user-select:none;position:relative;display:flex;align-items:center;justify-content:space-between;gap:14px}
details.ux-accordion>summary::-webkit-details-marker{display:none}
details.ux-accordion>summary:after{content:"";width:10px;height:10px;border-right:2px solid var(--muted);border-bottom:2px solid var(--muted);transform:rotate(45deg);transition:transform .18s ease;margin-left:auto;flex:0 0 auto}
details.ux-accordion[open]>summary:after{transform:rotate(225deg);margin-top:6px}
details.ux-accordion>summary small{display:block;color:var(--muted);font-size:.82rem;font-weight:500;margin-top:2px;line-height:1.35}
.builder-card.ux-accordion{padding:0;margin-bottom:20px;background:rgba(255,255,255,.96);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-soft)}
.builder-card.ux-accordion>.builder-card-header{padding:18px 22px;border-bottom:1px solid var(--line);background:linear-gradient(135deg,#fff,#f8fbfd)}
.builder-card.ux-accordion:not([open])>.builder-card-header{border-bottom:0}
.builder-card.ux-accordion .builder-card-body{padding:22px}
.add-question-accordion:not([open]){border-style:dashed;background:#fbfdff}.add-question-accordion:not([open]) summary{color:var(--navy)}
.side-card.ux-accordion{padding:0}.side-card.ux-accordion>summary{padding:18px 18px;border-bottom:1px solid var(--line);background:linear-gradient(135deg,#fff,#f8fbfd)}.side-card.ux-accordion:not([open])>summary{border-bottom:0}.side-card.ux-accordion>summary h2{margin:0}.side-card.ux-accordion>*:not(summary){margin-left:18px;margin-right:18px}.side-card.ux-accordion>*:last-child:not(summary){margin-bottom:18px}.side-card.ux-accordion .phone-preview{margin-top:16px}
.survey-card-details{margin-top:16px;border:1px solid var(--line);border-radius:18px;background:linear-gradient(135deg,#fbfdff,#f4f9fd)}.survey-card-details>summary{padding:13px 15px;color:var(--navy);font-weight:650}.survey-card-details>summary small{color:var(--muted);font-weight:500}.survey-card-details[open]>summary{border-bottom:1px solid var(--line)}.survey-card-details>.share-box,.survey-card-details>.copy-info,.survey-card-details>.survey-actions,.survey-card-details>.danger-zone{margin-left:14px;margin-right:14px}.survey-card-details>.share-box{margin-top:14px}.survey-card-details>.danger-zone{margin-bottom:14px}.survey-card-details:not([open])+.muted{display:block;margin-top:14px}
@media(max-width:900px){.builder-card.ux-accordion>.builder-card-header,.side-card.ux-accordion>summary{padding:16px}.builder-card.ux-accordion .builder-card-body{padding:16px}.survey-card-details>summary{display:grid;gap:3px}}
