:root{--bg: #f5f1e8;--paper: rgba(255, 252, 247, .84);--paper-strong: rgba(255, 250, 243, .95);--ink: #211a14;--muted: #6c6257;--line: rgba(33, 26, 20, .12);--line-strong: rgba(33, 26, 20, .22);--accent: #b95c34;--accent-soft: #e6b08a;--accent-dark: #6a2f1d;--panel-shadow: 0 20px 50px rgba(60, 37, 20, .12);font-family:Segoe UI,PingFang SC,sans-serif;color:var(--ink);background:radial-gradient(circle at top left,rgba(236,184,134,.35),transparent 28%),radial-gradient(circle at right 10%,rgba(103,164,145,.18),transparent 22%),linear-gradient(180deg,#f6f0e7,#efe6d8)}*{box-sizing:border-box}body{margin:0;min-height:100vh}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit}.app-shell{width:min(1440px,calc(100vw - 32px));margin:0 auto;padding:24px 0 48px}.loading-shell{min-height:100vh;display:grid;place-items:center;color:var(--muted)}.topbar,.panel,.auth-panel,.template-tabs,.admin-tabs{background:var(--paper);border:1px solid var(--line);border-radius:24px;box-shadow:var(--panel-shadow);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.topbar{display:flex;justify-content:space-between;gap:20px;align-items:center;padding:24px 28px}.topbar h1,.panel h2,.panel h3,.auth-panel h1{margin:0;font-family:Georgia,"Noto Serif SC",serif}.topbar__actions,.auth-toggle,.template-tabs,.admin-tabs,.row-actions,.submit-bar__actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.user-chip{display:flex;flex-direction:column;gap:2px;padding:10px 14px;border-radius:16px;background:#ffffffa6;border:1px solid var(--line)}.section-label{margin:0 0 6px;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}.muted-copy,.feedback,.slot-card__desc,.slot-card__meta,.history-item span,.user-card span,.template-admin-card span{color:var(--muted);line-height:1.7}.feedback{margin:16px 0 0;padding:14px 16px;border-radius:16px;background:#ffffffb3;border:1px solid var(--line)}.feedback--error{color:#9a2f1f;border-color:#9a2f1f2e}.feedback--success{color:#1c6a4c;border-color:#1c6a4c2e}.tab-button,.ghost-button,.primary-button,.download-link{display:inline-flex;align-items:center;justify-content:center;min-height:44px;border-radius:14px;border:1px solid var(--line-strong);padding:0 16px;cursor:pointer;transition:.18s ease}.tab-button,.ghost-button{background:#fff9;color:var(--ink)}.tab-button--active,.primary-button,.download-link{background:linear-gradient(135deg,var(--accent-soft),var(--accent));color:#fff6ef;border-color:transparent}.ghost-button--small{min-height:38px;padding:0 12px}.ghost-button--danger{color:#8c2d21;border-color:#8c2d213d}button:disabled{opacity:.6;cursor:not-allowed}.user-admin-actions{gap:10px;margin-top:10px}.user-admin-actions__button{min-height:34px;padding:0 12px;border-radius:12px;font-size:14px;white-space:nowrap}.template-save-bar{position:sticky;top:8px;z-index:20;display:flex;gap:12px;flex-wrap:wrap;margin-top:16px;padding:12px 14px;border-radius:18px;background:#fffaf3f5;border:1px solid var(--line);box-shadow:0 12px 24px #3c25141f;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.template-secondary-actions{gap:10px}.auth-shell{min-height:calc(100vh - 120px);display:grid;place-items:center}.auth-panel{width:min(560px,100%);padding:40px}.auth-form,.stack-form{display:flex;flex-direction:column;gap:16px;margin-top:20px}.auth-form label,.stack-form label,.filter-bar label,.slot-card,.slot-editor-row{display:flex;flex-direction:column;gap:8px}input,textarea,select{width:100%;border-radius:14px;border:1px solid var(--line-strong);background:#ffffffe0;padding:12px 14px;color:var(--ink)}textarea{min-height:120px;resize:vertical}.template-tabs,.admin-tabs{margin-top:18px;padding:14px}.workspace-grid,.admin-grid{margin-top:18px;display:grid;gap:18px}.workspace-grid--main{grid-template-columns:minmax(0,1.45fr) minmax(320px,.75fr);align-items:start}.admin-grid{grid-template-columns:minmax(320px,.85fr) minmax(0,1.15fr)}.panel{padding:24px}.panel--sidepanel{position:sticky;top:20px;align-self:start}.panel__header{display:flex;justify-content:space-between;gap:16px;align-items:center}.panel__header--stack{align-items:flex-start;flex-direction:column}.slot-group+.slot-group,.history-panel,.admin-shell{margin-top:18px}.slot-list,.history-list,.entry-list-panel,.entry-admin-list,.user-list,.template-admin-list,.slot-editor-list,.default-text-editor{display:flex;flex-direction:column;gap:12px;margin-top:16px}.slot-list--text{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.student-name-block{margin-bottom:20px}.slot-card--name{max-width:360px}.student-name-input{max-width:220px;min-height:44px}.slot-card,.history-item,.entry-card,.entry-admin-card,.user-card,.template-admin-card,.slot-editor-row{padding:16px;border-radius:18px;border:1px solid var(--line);background:#ffffffb8}.slot-card__title,.entry-card__meta,.slot-editor-row__head,.active-target{display:flex;justify-content:space-between;gap:12px;align-items:center}.slot-card__title,.history-item strong,.user-card strong,.template-admin-card strong,.slot-editor-row__head strong{font-weight:700}.slot-card__value{color:var(--accent-dark);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.slot-card__actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.slot-card__file-input{display:none}.slot-card__preview{width:100%;max-width:280px;aspect-ratio:4 / 3;object-fit:contain;object-position:left top;background:linear-gradient(135deg,#ffffffb8,#e6b08a1f);border:1px solid var(--line);border-radius:14px}.slot-card--active{border-color:#b95c3480;box-shadow:0 0 0 3px #b95c3429}.slot-card--text textarea{min-height:180px}.filter-bar{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:16px}.active-target{margin-top:16px;padding:14px 16px;border-radius:16px;background:#ffffffc7;border:1px solid var(--line)}.entry-list-panel{margin-top:16px;min-height:460px;max-height:calc(100vh - 220px);overflow:auto;padding-right:6px}.entry-card{text-align:left;cursor:pointer}.entry-card__meta{color:var(--accent-dark);font-size:13px}.entry-card p{margin:12px 0 0;line-height:1.8;white-space:pre-wrap}.submit-bar{margin-top:18px;display:flex;justify-content:space-between;gap:16px;align-items:center}.history-item,.user-card,.template-admin-card{display:flex;flex-direction:column;gap:4px}.history-item--compact{flex-direction:row;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px}.history-item__summary,.history-item__actions{display:flex;align-items:center;gap:10px}.history-item__summary{min-width:0;flex:1;flex-wrap:wrap}.history-item__summary strong,.history-item__summary span{min-width:0;white-space:nowrap}.history-item__summary strong{overflow:hidden;text-overflow:ellipsis;max-width:min(100%,520px)}.history-item__summary span{line-height:1.4}.history-item__actions{flex-shrink:0}.history-item__action{min-height:36px;padding:0 12px;border-radius:12px}.template-admin-card,.user-card{text-align:left;cursor:pointer}.template-admin-card--active,.user-card--active{border-color:#b95c346b;box-shadow:0 0 0 3px #b95c341f}.entry-admin-card textarea{min-height:160px}.entry-admin-card__filters{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}.default-text-item{display:flex;flex-direction:column;gap:8px}.default-text-trigger{width:100%;justify-content:center}.modal-backdrop{position:fixed;inset:0;z-index:1000;display:grid;place-items:center;padding:24px;background:#211a1461;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.modal-panel{width:min(920px,100%);max-height:min(86vh,900px);overflow:hidden;padding:24px;border-radius:24px;border:1px solid var(--line);background:var(--paper-strong);box-shadow:var(--panel-shadow)}.modal-panel--default-text{display:flex;flex-direction:column;gap:16px}.default-text-picker-list{display:flex;flex-direction:column;gap:14px;min-height:320px;max-height:56vh;overflow-y:auto;padding-right:6px}.default-text-picker-item{width:100%;display:flex;flex-direction:column;gap:10px;padding:16px;text-align:left;border-radius:18px;border:1px solid var(--line);background:#ffffffbf}.default-text-picker-item--active{border-color:#b95c3480;box-shadow:0 0 0 3px #b95c3429}.default-text-picker-item__title{font-weight:700;color:var(--accent-dark)}.default-text-picker-item__content{min-height:180px;font-size:16px;line-height:1.8;resize:none;cursor:text}.checkbox-row{flex-direction:row!important;align-items:center}.checkbox-row input{width:auto}.upload-box{position:relative;min-height:88px;border:1px dashed rgba(185,92,52,.42);border-radius:18px;justify-content:center;align-items:center;color:var(--accent-dark);background:#ffffffbd;overflow:hidden}.upload-box input{position:absolute;inset:0;opacity:0;cursor:pointer}.empty-panel{margin-top:18px;text-align:center}@media(max-width:1080px){.topbar,.workspace-grid--main,.admin-grid,.submit-bar,.slot-card__title,.active-target{grid-template-columns:1fr;flex-direction:column;align-items:flex-start}.workspace-grid--main,.admin-grid{display:grid}.panel--sidepanel{position:static;top:auto}.filter-bar,.entry-admin-card__filters{grid-template-columns:1fr}.app-shell{width:min(100vw - 20px,1440px)}.auth-panel{padding:28px}.modal-backdrop{padding:12px}.modal-panel{padding:18px}.default-text-picker-item__content{min-height:140px}.history-item--compact{flex-direction:column;align-items:flex-start}.history-item__actions{width:100%;justify-content:flex-start;flex-wrap:wrap}}
