div.ql-editor {
    --blot-align-left-margin: 0.5rem 1rem 0.5rem 0;
    --blot-align-center-margin: 1rem auto;
    --blot-align-right-margin: 0.5rem 0 0.5rem 1rem;
}

/* image wrapper common */
div.ql-editor [class^="ql-image-align-"] {
    display: flex;
    flex-wrap: wrap;
    width: var(--resize-width);
    max-width: 100%;
}

div.ql-editor [class^="ql-image-align-"]>img {
    flex: 1 1 auto;
    z-index: 1;
}

/* left */
div.ql-editor .ql-image-align-left,
div.ql-editor .ql-iframe-align-left {
    margin: var(--blot-align-left-margin);
    float: left;
}

/* centre */
div.ql-editor .ql-image-align-center,
div.ql-editor .ql-iframe-align-center {
    margin: var(--blot-align-center-margin);
}

/* right */
div.ql-editor .ql-image-align-right,
div.ql-editor .ql-iframe-align-right {
    margin: var(--blot-align-right-margin);
    float: right;
}

/* image caption */
/* common */
div.ql-editor [class^="ql-image-align-"][data-title] {
    margin-bottom: 0;
}

div.ql-editor [class^="ql-image-align-"][data-title]::after {
    content: attr(data-title);
    padding: 0.25rem 0.2rem;
    font-size: 0.9rem;
    line-height: 1.1;
    background-color: white;
    width: 100%;
}

/* remove text decoration on caption when image linked */
a:has([class^="ql-image-align-"]>img) {
    text-decoration: none !important;
}

/* left */
div.ql-editor .ql-image-align-left[data-title]::after {
    text-align: left;
}

/* center */
div.ql-editor .ql-image-align-center[data-title]::after {
    text-align: center;
}

/* right */
div.ql-editor .ql-image-align-right[data-title]::after {
    text-align: right;
}/*!
 * Quill Editor v2.0.3
 * https://quilljs.com
 * Copyright (c) 2017-2024, Slab
 * Copyright (c) 2014, Jason Chen
 * Copyright (c) 2013, salesforce.com
 */
.ql-container{box-sizing:border-box;font-family:Helvetica,Arial,sans-serif;font-size:13px;height:100%;margin:0;position:relative}.ql-container.ql-disabled .ql-tooltip{visibility:hidden}.ql-container:not(.ql-disabled) li[data-list=checked] > .ql-ui,.ql-container:not(.ql-disabled) li[data-list=unchecked] > .ql-ui{cursor:pointer}.ql-clipboard{left:-100000px;height:1px;overflow-y:hidden;position:absolute;top:50%}.ql-clipboard p{margin:0;padding:0}.ql-editor{box-sizing:border-box;counter-reset:list-0 list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9;line-height:1.42;height:100%;outline:none;overflow-y:auto;padding:12px 15px;tab-size:4;-moz-tab-size:4;text-align:left;white-space:pre-wrap;word-wrap:break-word}.ql-editor > *{cursor:text}.ql-editor p,.ql-editor ol,.ql-editor pre,.ql-editor blockquote,.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6{margin:0;padding:0}@supports (counter-set:none){.ql-editor p,.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6{counter-set:list-0 list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor p,.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6{counter-reset:list-0 list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor table{border-collapse:collapse}.ql-editor td{border:1px solid #000;padding:2px 5px}.ql-editor ol{padding-left:1.5em}.ql-editor li{list-style-type:none;padding-left:1.5em;position:relative}.ql-editor li > .ql-ui:before{display:inline-block;margin-left:-1.5em;margin-right:.3em;text-align:right;white-space:nowrap;width:1.2em}.ql-editor li[data-list=checked] > .ql-ui,.ql-editor li[data-list=unchecked] > .ql-ui{color:#777}.ql-editor li[data-list=bullet] > .ql-ui:before{content:'\2022'}.ql-editor li[data-list=checked] > .ql-ui:before{content:'\2611'}.ql-editor li[data-list=unchecked] > .ql-ui:before{content:'\2610'}@supports (counter-set:none){.ql-editor li[data-list]{counter-set:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list]{counter-reset:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered]{counter-increment:list-0}.ql-editor li[data-list=ordered] > .ql-ui:before{content:counter(list-0, decimal) '. '}.ql-editor li[data-list=ordered].ql-indent-1{counter-increment:list-1}.ql-editor li[data-list=ordered].ql-indent-1 > .ql-ui:before{content:counter(list-1, lower-alpha) '. '}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-1{counter-set:list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-1{counter-reset:list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-2{counter-increment:list-2}.ql-editor li[data-list=ordered].ql-indent-2 > .ql-ui:before{content:counter(list-2, lower-roman) '. '}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-2{counter-set:list-3 list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-2{counter-reset:list-3 list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-3{counter-increment:list-3}.ql-editor li[data-list=ordered].ql-indent-3 > .ql-ui:before{content:counter(list-3, decimal) '. '}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-3{counter-set:list-4 list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-3{counter-reset:list-4 list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-4{counter-increment:list-4}.ql-editor li[data-list=ordered].ql-indent-4 > .ql-ui:before{content:counter(list-4, lower-alpha) '. '}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-4{counter-set:list-5 list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-4{counter-reset:list-5 list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-5{counter-increment:list-5}.ql-editor li[data-list=ordered].ql-indent-5 > .ql-ui:before{content:counter(list-5, lower-roman) '. '}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-5{counter-set:list-6 list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-5{counter-reset:list-6 list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-6{counter-increment:list-6}.ql-editor li[data-list=ordered].ql-indent-6 > .ql-ui:before{content:counter(list-6, decimal) '. '}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-6{counter-set:list-7 list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-6{counter-reset:list-7 list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-7{counter-increment:list-7}.ql-editor li[data-list=ordered].ql-indent-7 > .ql-ui:before{content:counter(list-7, lower-alpha) '. '}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-7{counter-set:list-8 list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-7{counter-reset:list-8 list-9}}.ql-editor li[data-list=ordered].ql-indent-8{counter-increment:list-8}.ql-editor li[data-list=ordered].ql-indent-8 > .ql-ui:before{content:counter(list-8, lower-roman) '. '}@supports (counter-set:none){.ql-editor li[data-list].ql-indent-8{counter-set:list-9}}@supports not (counter-set:none){.ql-editor li[data-list].ql-indent-8{counter-reset:list-9}}.ql-editor li[data-list=ordered].ql-indent-9{counter-increment:list-9}.ql-editor li[data-list=ordered].ql-indent-9 > .ql-ui:before{content:counter(list-9, decimal) '. '}.ql-editor .ql-indent-1:not(.ql-direction-rtl){padding-left:3em}.ql-editor li.ql-indent-1:not(.ql-direction-rtl){padding-left:4.5em}.ql-editor .ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:3em}.ql-editor li.ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:4.5em}.ql-editor .ql-indent-2:not(.ql-direction-rtl){padding-left:6em}.ql-editor li.ql-indent-2:not(.ql-direction-rtl){padding-left:7.5em}.ql-editor .ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:6em}.ql-editor li.ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:7.5em}.ql-editor .ql-indent-3:not(.ql-direction-rtl){padding-left:9em}.ql-editor li.ql-indent-3:not(.ql-direction-rtl){padding-left:10.5em}.ql-editor .ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:9em}.ql-editor li.ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:10.5em}.ql-editor .ql-indent-4:not(.ql-direction-rtl){padding-left:12em}.ql-editor li.ql-indent-4:not(.ql-direction-rtl){padding-left:13.5em}.ql-editor .ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:12em}.ql-editor li.ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:13.5em}.ql-editor .ql-indent-5:not(.ql-direction-rtl){padding-left:15em}.ql-editor li.ql-indent-5:not(.ql-direction-rtl){padding-left:16.5em}.ql-editor .ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:15em}.ql-editor li.ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:16.5em}.ql-editor .ql-indent-6:not(.ql-direction-rtl){padding-left:18em}.ql-editor li.ql-indent-6:not(.ql-direction-rtl){padding-left:19.5em}.ql-editor .ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:18em}.ql-editor li.ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:19.5em}.ql-editor .ql-indent-7:not(.ql-direction-rtl){padding-left:21em}.ql-editor li.ql-indent-7:not(.ql-direction-rtl){padding-left:22.5em}.ql-editor .ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:21em}.ql-editor li.ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:22.5em}.ql-editor .ql-indent-8:not(.ql-direction-rtl){padding-left:24em}.ql-editor li.ql-indent-8:not(.ql-direction-rtl){padding-left:25.5em}.ql-editor .ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:24em}.ql-editor li.ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:25.5em}.ql-editor .ql-indent-9:not(.ql-direction-rtl){padding-left:27em}.ql-editor li.ql-indent-9:not(.ql-direction-rtl){padding-left:28.5em}.ql-editor .ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:27em}.ql-editor li.ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:28.5em}.ql-editor li.ql-direction-rtl{padding-right:1.5em}.ql-editor li.ql-direction-rtl > .ql-ui:before{margin-left:.3em;margin-right:-1.5em;text-align:left}.ql-editor table{table-layout:fixed;width:100%}.ql-editor table td{outline:none}.ql-editor .ql-code-block-container{font-family:monospace}.ql-editor .ql-video{display:block;max-width:100%}.ql-editor .ql-video.ql-align-center{margin:0 auto}.ql-editor .ql-video.ql-align-right{margin:0 0 0 auto}.ql-editor .ql-bg-black{background-color:#000}.ql-editor .ql-bg-red{background-color:#e60000}.ql-editor .ql-bg-orange{background-color:#f90}.ql-editor .ql-bg-yellow{background-color:#ff0}.ql-editor .ql-bg-green{background-color:#008a00}.ql-editor .ql-bg-blue{background-color:#06c}.ql-editor .ql-bg-purple{background-color:#93f}.ql-editor .ql-color-white{color:#fff}.ql-editor .ql-color-red{color:#e60000}.ql-editor .ql-color-orange{color:#f90}.ql-editor .ql-color-yellow{color:#ff0}.ql-editor .ql-color-green{color:#008a00}.ql-editor .ql-color-blue{color:#06c}.ql-editor .ql-color-purple{color:#93f}.ql-editor .ql-font-serif{font-family:Georgia,Times New Roman,serif}.ql-editor .ql-font-monospace{font-family:Monaco,Courier New,monospace}.ql-editor .ql-size-small{font-size:.75em}.ql-editor .ql-size-large{font-size:1.5em}.ql-editor .ql-size-huge{font-size:2.5em}.ql-editor .ql-direction-rtl{direction:rtl;text-align:inherit}.ql-editor .ql-align-center{text-align:center}.ql-editor .ql-align-justify{text-align:justify}.ql-editor .ql-align-right{text-align:right}.ql-editor .ql-ui{position:absolute}.ql-editor.ql-blank::before{color:rgba(0,0,0,0.6);content:attr(data-placeholder);font-style:italic;left:15px;pointer-events:none;position:absolute;right:15px}.ql-snow.ql-toolbar:after,.ql-snow .ql-toolbar:after{clear:both;content:'';display:table}.ql-snow.ql-toolbar button,.ql-snow .ql-toolbar button{background:none;border:none;cursor:pointer;display:inline-block;float:left;height:24px;padding:3px 5px;width:28px}.ql-snow.ql-toolbar button svg,.ql-snow .ql-toolbar button svg{float:left;height:100%}.ql-snow.ql-toolbar button:active:hover,.ql-snow .ql-toolbar button:active:hover{outline:none}.ql-snow.ql-toolbar input.ql-image[type=file],.ql-snow .ql-toolbar input.ql-image[type=file]{display:none}.ql-snow.ql-toolbar button:hover,.ql-snow .ql-toolbar button:hover,.ql-snow.ql-toolbar button:focus,.ql-snow .ql-toolbar button:focus,.ql-snow.ql-toolbar button.ql-active,.ql-snow .ql-toolbar button.ql-active,.ql-snow.ql-toolbar .ql-picker-label:hover,.ql-snow .ql-toolbar .ql-picker-label:hover,.ql-snow.ql-toolbar .ql-picker-label.ql-active,.ql-snow .ql-toolbar .ql-picker-label.ql-active,.ql-snow.ql-toolbar .ql-picker-item:hover,.ql-snow .ql-toolbar .ql-picker-item:hover,.ql-snow.ql-toolbar .ql-picker-item.ql-selected,.ql-snow .ql-toolbar .ql-picker-item.ql-selected{color:#06c}.ql-snow.ql-toolbar button:hover .ql-fill,.ql-snow .ql-toolbar button:hover .ql-fill,.ql-snow.ql-toolbar button:focus .ql-fill,.ql-snow .ql-toolbar button:focus .ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow.ql-toolbar button:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill{fill:#06c}.ql-snow.ql-toolbar button:hover .ql-stroke,.ql-snow .ql-toolbar button:hover .ql-stroke,.ql-snow.ql-toolbar button:focus .ql-stroke,.ql-snow .ql-toolbar button:focus .ql-stroke,.ql-snow.ql-toolbar button.ql-active .ql-stroke,.ql-snow .ql-toolbar button.ql-active .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow.ql-toolbar button:hover .ql-stroke-miter,.ql-snow .ql-toolbar button:hover .ql-stroke-miter,.ql-snow.ql-toolbar button:focus .ql-stroke-miter,.ql-snow .ql-toolbar button:focus .ql-stroke-miter,.ql-snow.ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter{stroke:#06c}@media (pointer:coarse){.ql-snow.ql-toolbar button:hover:not(.ql-active),.ql-snow .ql-toolbar button:hover:not(.ql-active){color:#444}.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill{fill:#444}.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter{stroke:#444}}.ql-snow{box-sizing:border-box}.ql-snow *{box-sizing:border-box}.ql-snow .ql-hidden{display:none}.ql-snow .ql-out-bottom,.ql-snow .ql-out-top{visibility:hidden}.ql-snow .ql-tooltip{position:absolute;transform:translateY(10px)}.ql-snow .ql-tooltip a{cursor:pointer;text-decoration:none}.ql-snow .ql-tooltip.ql-flip{transform:translateY(-10px)}.ql-snow .ql-formats{display:inline-block;vertical-align:middle}.ql-snow .ql-formats:after{clear:both;content:'';display:table}.ql-snow .ql-stroke{fill:none;stroke:#444;stroke-linecap:round;stroke-linejoin:round;stroke-width:2}.ql-snow .ql-stroke-miter{fill:none;stroke:#444;stroke-miterlimit:10;stroke-width:2}.ql-snow .ql-fill,.ql-snow .ql-stroke.ql-fill{fill:#444}.ql-snow .ql-empty{fill:none}.ql-snow .ql-even{fill-rule:evenodd}.ql-snow .ql-thin,.ql-snow .ql-stroke.ql-thin{stroke-width:1}.ql-snow .ql-transparent{opacity:.4}.ql-snow .ql-direction svg:last-child{display:none}.ql-snow .ql-direction.ql-active svg:last-child{display:inline}.ql-snow .ql-direction.ql-active svg:first-child{display:none}.ql-snow .ql-editor h1{font-size:2em}.ql-snow .ql-editor h2{font-size:1.5em}.ql-snow .ql-editor h3{font-size:1.17em}.ql-snow .ql-editor h4{font-size:1em}.ql-snow .ql-editor h5{font-size:.83em}.ql-snow .ql-editor h6{font-size:.67em}.ql-snow .ql-editor a{text-decoration:underline}.ql-snow .ql-editor blockquote{border-left:4px solid #ccc;margin-bottom:5px;margin-top:5px;padding-left:16px}.ql-snow .ql-editor code,.ql-snow .ql-editor .ql-code-block-container{background-color:#f0f0f0;border-radius:3px}.ql-snow .ql-editor .ql-code-block-container{margin-bottom:5px;margin-top:5px;padding:5px 10px}.ql-snow .ql-editor code{font-size:85%;padding:2px 4px}.ql-snow .ql-editor .ql-code-block-container{background-color:#23241f;color:#f8f8f2;overflow:visible}.ql-snow .ql-editor img{max-width:100%}.ql-snow .ql-picker{color:#444;display:inline-block;float:left;font-size:14px;font-weight:500;height:24px;position:relative;vertical-align:middle}.ql-snow .ql-picker-label{cursor:pointer;display:inline-block;height:100%;padding-left:8px;padding-right:2px;position:relative;width:100%}.ql-snow .ql-picker-label::before{display:inline-block;line-height:22px}.ql-snow .ql-picker-options{background-color:#fff;display:none;min-width:100%;padding:4px 8px;position:absolute;white-space:nowrap}.ql-snow .ql-picker-options .ql-picker-item{cursor:pointer;display:block;padding-bottom:5px;padding-top:5px}.ql-snow .ql-picker.ql-expanded .ql-picker-label{color:#ccc;z-index:2}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-fill{fill:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-stroke{stroke:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-options{display:block;margin-top:-1px;top:100%;z-index:1}.ql-snow .ql-color-picker,.ql-snow .ql-icon-picker{width:28px}.ql-snow .ql-color-picker .ql-picker-label,.ql-snow .ql-icon-picker .ql-picker-label{padding:2px 4px}.ql-snow .ql-color-picker .ql-picker-label svg,.ql-snow .ql-icon-picker .ql-picker-label svg{right:4px}.ql-snow .ql-icon-picker .ql-picker-options{padding:4px 0}.ql-snow .ql-icon-picker .ql-picker-item{height:24px;width:24px;padding:2px 4px}.ql-snow .ql-color-picker .ql-picker-options{padding:3px 5px;width:152px}.ql-snow .ql-color-picker .ql-picker-item{border:1px solid transparent;float:left;height:16px;margin:2px;padding:0;width:16px}.ql-snow .ql-picker:not(.ql-color-picker):not(.ql-icon-picker) svg{position:absolute;margin-top:-9px;right:0;top:50%;width:18px}.ql-snow .ql-picker.ql-header .ql-picker-label[data-label]:not([data-label=''])::before,.ql-snow .ql-picker.ql-font .ql-picker-label[data-label]:not([data-label=''])::before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-label]:not([data-label=''])::before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-label]:not([data-label=''])::before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-label]:not([data-label=''])::before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-label]:not([data-label=''])::before{content:attr(data-label)}.ql-snow .ql-picker.ql-header{width:98px}.ql-snow .ql-picker.ql-header .ql-picker-label::before,.ql-snow .ql-picker.ql-header .ql-picker-item::before{content:'Normal'}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="1"]::before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]::before{content:'Heading 1'}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="2"]::before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]::before{content:'Heading 2'}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="3"]::before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]::before{content:'Heading 3'}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="4"]::before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]::before{content:'Heading 4'}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="5"]::before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]::before{content:'Heading 5'}.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="6"]::before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]::before{content:'Heading 6'}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]::before{font-size:2em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]::before{font-size:1.5em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]::before{font-size:1.17em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]::before{font-size:1em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]::before{font-size:.83em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]::before{font-size:.67em}.ql-snow .ql-picker.ql-font{width:108px}.ql-snow .ql-picker.ql-font .ql-picker-label::before,.ql-snow .ql-picker.ql-font .ql-picker-item::before{content:'Sans Serif'}.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=serif]::before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]::before{content:'Serif'}.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=monospace]::before,.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]::before{content:'Monospace'}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]::before{font-family:Georgia,Times New Roman,serif}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]::before{font-family:Monaco,Courier New,monospace}.ql-snow .ql-picker.ql-size{width:98px}.ql-snow .ql-picker.ql-size .ql-picker-label::before,.ql-snow .ql-picker.ql-size .ql-picker-item::before{content:'Normal'}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=small]::before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]::before{content:'Small'}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=large]::before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]::before{content:'Large'}.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=huge]::before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]::before{content:'Huge'}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]::before{font-size:10px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]::before{font-size:18px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]::before{font-size:32px}.ql-snow .ql-color-picker.ql-background .ql-picker-item{background-color:#fff}.ql-snow .ql-color-picker.ql-color .ql-picker-item{background-color:#000}.ql-code-block-container{position:relative}.ql-code-block-container .ql-ui{right:5px;top:5px}.ql-toolbar.ql-snow{border:1px solid #ccc;box-sizing:border-box;font-family:'Helvetica Neue','Helvetica','Arial',sans-serif;padding:8px}.ql-toolbar.ql-snow .ql-formats{margin-right:15px}.ql-toolbar.ql-snow .ql-picker-label{border:1px solid transparent}.ql-toolbar.ql-snow .ql-picker-options{border:1px solid transparent;box-shadow:rgba(0,0,0,0.2) 0 2px 8px}.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-label{border-color:#ccc}.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-options{border-color:#ccc}.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item.ql-selected,.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item:hover{border-color:#000}.ql-toolbar.ql-snow + .ql-container.ql-snow{border-top:0}.ql-snow .ql-tooltip{background-color:#fff;border:1px solid #ccc;box-shadow:0 0 5px #ddd;color:#444;padding:5px 12px;white-space:nowrap}.ql-snow .ql-tooltip::before{content:"Visit URL:";line-height:26px;margin-right:8px}.ql-snow .ql-tooltip input[type=text]{display:none;border:1px solid #ccc;font-size:13px;height:26px;margin:0;padding:3px 5px;width:170px}.ql-snow .ql-tooltip a.ql-preview{display:inline-block;max-width:200px;overflow-x:hidden;text-overflow:ellipsis;vertical-align:top}.ql-snow .ql-tooltip a.ql-action::after{border-right:1px solid #ccc;content:'Edit';margin-left:16px;padding-right:8px}.ql-snow .ql-tooltip a.ql-remove::before{content:'Remove';margin-left:8px}.ql-snow .ql-tooltip a{line-height:26px}.ql-snow .ql-tooltip.ql-editing a.ql-preview,.ql-snow .ql-tooltip.ql-editing a.ql-remove{display:none}.ql-snow .ql-tooltip.ql-editing input[type=text]{display:inline-block}.ql-snow .ql-tooltip.ql-editing a.ql-action::after{border-right:0;content:'Save';padding-right:0}.ql-snow .ql-tooltip[data-mode=link]::before{content:"Enter link:"}.ql-snow .ql-tooltip[data-mode=formula]::before{content:"Enter formula:"}.ql-snow .ql-tooltip[data-mode=video]::before{content:"Enter video:"}.ql-snow a{color:#06c}.ql-container.ql-snow{border:1px solid #ccc}

/*# sourceMappingURL=quill.snow.css.map*/.ql-container{position:relative;overflow:hidden}@media(pointer: coarse){.ql-cursor-caret-container{z-index:-1}}.ql-cursor.hidden{display:none}.ql-cursor .ql-cursor-caret-container,.ql-cursor .ql-cursor-flag{position:absolute}.ql-cursor .ql-cursor-flag{z-index:1;transform:translate3d(-1px, -100%, 0);opacity:0;visibility:hidden;color:#fff;padding-bottom:2px;border-radius:0 3px 3px 0}.ql-cursor .ql-cursor-flag.flag-flipped{border-radius:3px 0 0 3px;transform:translate3d(calc(-100% + 1px ), -100%, 0)}@media screen{.ql-cursor .ql-cursor-flag{transition:opacity 0ms cubic-bezier(0.25, 0.46, 0.45, 0.94) 0ms,visibility 0ms cubic-bezier(0.25, 0.46, 0.45, 0.94) 0ms}}.ql-cursor .ql-cursor-flag .ql-cursor-name{margin-left:5px;margin-right:5px;display:inline-block;margin-top:-2px;white-space:nowrap}.ql-cursor .ql-cursor-flag.no-delay[style]{transition-delay:unset !important}.ql-cursor .ql-cursor-caret-container{cursor:text;margin-left:-9px;padding:0 9px}.ql-cursor .ql-cursor-caret-container.hover+.ql-cursor-flag{opacity:1;visibility:visible;transition:none}.ql-cursor .ql-cursor-caret-container.no-pointer{pointer-events:none}.ql-cursor .ql-cursor-caret-container .ql-cursor-caret{position:absolute;top:0;bottom:0;width:2px;margin-left:-1px;background-color:attr(data-color)}.ql-cursor .ql-cursor-selection-block{position:absolute;pointer-events:none}
:root {
  color-scheme: light;
  font-family: "Aptos", "Segoe UI", sans-serif;
  --space-stack: 1rem;
  --space-section: 1.5rem;
  --radius-xs: 6px;
  --radius-sm: 8px;
  --radius-md: 10px;
  --radius-lg: 12px;
  --radius-xl: 14px;
  --radius-2xl: 16px;
  --brand-navy: #16324f;
  --brand-navy-deep: #1a375c;
  --brand-blue: #245b85;
  --brand-blue-bright: #2f78a8;
  --brand-blue-soft: #90c0eb;
  --brand-blue-pale: #c7e9ff;
  --brand-blue-mist: #e1eefa;
  --text-strong: #18324a;
  --text-muted: #5e7388;
  --surface-card: rgba(255, 255, 255, 0.84);
  --surface-panel: rgba(245, 250, 255, 0.88);
  --border-soft: rgba(22, 50, 79, 0.1);
  --status-green-bg: rgba(89, 173, 114, 0.16);
  --status-green-text: #2f8f46;
  --status-yellow-bg: rgba(212, 173, 36, 0.2);
  --status-yellow-text: #8d6900;
  --status-red-bg: rgba(215, 111, 104, 0.18);
  --status-red-text: #b43a32;
  background:
    radial-gradient(circle at top left, rgba(144, 192, 235, 0.42), transparent 32%),
    radial-gradient(circle at 85% 18%, rgba(198, 224, 246, 0.32), transparent 26%),
    radial-gradient(circle at bottom right, rgba(47, 120, 168, 0.2), transparent 34%),
    linear-gradient(180deg, #f6fbff 0%, #edf4fb 42%, #e2edf8 100%);
  color: var(--text-strong);
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  min-height: 100vh;
  background:
    radial-gradient(circle at top left, rgba(144, 192, 235, 0.42), transparent 32%),
    radial-gradient(circle at 85% 18%, rgba(198, 224, 246, 0.32), transparent 26%),
    radial-gradient(circle at bottom right, rgba(47, 120, 168, 0.2), transparent 34%),
    linear-gradient(180deg, #f6fbff 0%, #edf4fb 42%, #e2edf8 100%);
}

a {
  color: var(--brand-blue);
  text-decoration: none;
}

button,
input,
select,
textarea {
  font: inherit;
}

.portal-nav,
.stack {
  display: grid;
  gap: var(--space-stack);
}

.district-sidebar-content {
  display: flex;
  flex: 1;
  min-width: 0;
  width: 100%;
  flex-direction: column;
}

.district-sidebar-content-collapsed {
  align-items: center;
}

.auth-summary-card {
  display: grid;
  gap: 0.35rem;
  margin-top: auto;
  padding: 0.8rem;
  border-radius: var(--radius-sm);
  color: #f8fbff;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.18);
}

.auth-summary-card-collapsed {
  justify-items: center;
  padding: 0;
  background: transparent;
  border: 0;
}

.auth-summary-card small {
  color: rgba(248, 251, 255, 0.72);
  word-break: break-word;
}

.ghost-button {
  min-height: 2rem;
  padding: 0.35rem 0.65rem;
  border: 1px solid rgba(22, 50, 79, 0.18);
  border-radius: var(--radius-xs);
  background: rgba(255, 255, 255, 0.92);
  color: var(--brand-navy);
  cursor: pointer;
}

.auth-summary-card-collapsed .ghost-button {
  width: 2.6rem;
  height: 2.6rem;
  padding: 0;
  font-size: 1.05rem;
  font-weight: 800;
}

.page-stack {
  display: grid;
  gap: var(--space-section);
}

.portal-link,
.student-subnav-link {
  display: grid;
  gap: 0.2rem;
  padding: 0.72rem 0.8rem;
  border-radius: var(--radius-sm);
  color: rgba(248, 251, 255, 0.9);
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.15);
  transition: background 140ms ease, border-color 140ms ease, color 140ms ease, transform 140ms ease;
}

.portal-link.active,
.student-subnav-link.active {
  background: rgba(255, 255, 255, 0.22);
  color: #f8fbff;
  border-color: rgba(255, 255, 255, 0.28);
}

.portal-link:hover {
  background: rgba(255, 255, 255, 0.18);
  border-color: rgba(255, 255, 255, 0.28);
  transform: translateX(2px);
}

.portal-link.active:hover {
  background: rgba(255, 255, 255, 0.24);
}

.portal-nav-collapsed {
  justify-items: center;
  gap: 0.55rem;
}

.portal-nav-collapsed .portal-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.6rem;
  height: 2.6rem;
  padding: 0;
  font-size: 1.05rem;
  font-weight: 800;
  line-height: 1;
}

.portal-nav-collapsed .portal-link:hover {
  transform: none;
}

.student-subnav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin: 0 0 1.5rem;
}

.student-subnav-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0.7rem 1rem;
  color: #16324f;
  background: rgba(199, 225, 246, 0.78);
  border-color: rgba(36, 91, 133, 0.28);
  font-weight: 700;
}

.student-subnav-link:hover {
  color: #0f2d56;
  background: rgba(176, 214, 241, 0.9);
  border-color: rgba(36, 91, 133, 0.42);
}

.student-subnav-link.active,
.student-subnav-link.active:hover {
  color: #f8fbff;
  background: #245b85;
  border-color: #1b496d;
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0.2rem 0.65rem;
  border-radius: var(--radius-lg);
  background: rgba(199, 233, 255, 0.18);
  color: #edf7ff;
  font-size: 0.8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.hero-card,
.student-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(260px, 0.9fr);
  gap: 1rem;
  margin-bottom: 1.5rem;
  padding: 1.4rem;
  border-radius: var(--radius-2xl);
  background: linear-gradient(135deg, rgba(22, 50, 79, 0.98), rgba(36, 91, 133, 0.92));
  color: #f8fbff;
  box-shadow: 0 28px 64px rgba(22, 50, 79, 0.18);
}

.hero-card.district,
.student-hero.district {
  background:
    radial-gradient(circle at top right, rgba(199, 233, 255, 0.16), transparent 30%),
    linear-gradient(135deg, rgba(22, 50, 79, 0.98), rgba(47, 120, 168, 0.9));
}

.hero-card h2,
.student-hero h2 {
  margin: 0.55rem 0 0.4rem;
  font-size: clamp(1.8rem, 3vw, 2.6rem);
  line-height: 1.05;
}

.hero-card p,
.student-hero p {
  margin: 0;
  color: rgba(248, 251, 255, 0.86);
  line-height: 1.6;
}

.hero-actions,
.student-hero-meta {
  display: grid;
  gap: 0.75rem;
  align-content: start;
}

.hero-action-link,
.student-summary-card,
.activity-row,
.risk-card {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem;
  border-radius: var(--radius-xl);
  background: rgba(255, 255, 255, 0.9);
  color: var(--text-strong);
}

.hero-action-link {
  flex-direction: column;
  background: rgba(255, 255, 255, 0.12);
  color: #f8fbff;
}

.hero-action-link.static {
  pointer-events: none;
}

.hero-action-link span,
.hero-action-link small {
  color: rgba(248, 251, 255, 0.82);
}

.student-summary-card {
  flex-direction: column;
  border: 1px solid var(--border-soft);
}

.student-summary-card small,
.activity-row p,
.risk-card p {
  margin: 0.2rem 0 0;
  color: var(--text-muted);
}

.metric-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--space-stack);
  margin-bottom: 1.5rem;
}

.two-column,
.three-column,
.document-grid {
  display: grid;
  gap: var(--space-stack);
}

.two-column {
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  margin-bottom: 1rem;
}

.three-column {
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  margin-bottom: 1rem;
}

.document-grid {
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.document-catalog-grid {
  grid-template-columns: repeat(auto-fit, minmax(340px, 1fr));
  max-width: 1220px;
  align-items: start;
}

.document-accordion {
  border-radius: var(--radius-2xl);
  background: rgba(255, 255, 255, 0.6);
  box-shadow: 0 20px 48px rgba(31, 45, 61, 0.06);
  padding: 0.5rem;
}

.document-accordion-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  list-style: none;
  cursor: pointer;
  padding: 0.9rem 1rem;
  border-radius: var(--radius-xl);
}

.document-accordion-summary::-webkit-details-marker {
  display: none;
}

.document-accordion-summary > div {
  display: grid;
  gap: 0.2rem;
}

.document-accordion-summary strong {
  font-size: 1.05rem;
}

.document-accordion-summary small {
  color: #67798d;
  font-weight: 600;
}

.document-accordion-indicator {
  color: #7f481a;
  font-weight: 700;
}

.document-accordion[open] .document-accordion-indicator::before {
  content: "Hide";
}

.document-accordion:not([open]) .document-accordion-indicator::before {
  content: "Show";
}

.document-accordion-indicator {
  font-size: 0;
}

.document-accordion .document-catalog-grid {
  padding: 0.25rem 0.25rem 0.5rem;
}

.compact-grid {
  align-items: start;
}

.chip-row,
.button-row,
.filter-row,
.editor-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.info-chip {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0.2rem 0.7rem;
  border-radius: var(--radius-lg);
  background: rgba(199, 233, 255, 0.45);
  color: var(--brand-blue);
  font-size: 0.82rem;
  font-weight: 700;
}

.plain-list {
  display: grid;
  gap: 0.65rem;
  margin: 0;
  padding-left: 1.1rem;
}

.field-label,
.editor-label {
  display: grid;
  gap: 0.45rem;
  align-content: start;
  min-width: 0;
}

.field-label {
  pointer-events: none;
}

.editor-label {
  gap: 0.75rem;
  padding: 0.7rem 0.25rem;
}

.field-label > span {
  display: block;
  color: var(--text-strong);
  font-weight: 700;
  line-height: 1.35;
}

.compact-grid .field-label > span {
  min-height: 2.45rem;
  display: flex;
  align-items: flex-end;
}

.narrative-editor-field {
  display: grid;
  gap: 0.65rem;
  align-content: start;
  position: relative;
  isolation: isolate;
}

.narrative-editor-field > span {
  position: relative;
  z-index: 2;
  margin: 0;
  padding: 0 0.15rem;
  background: linear-gradient(180deg, rgba(243, 248, 253, 0.96), rgba(243, 248, 253, 0.9));
  border-radius: var(--radius-xs);
}

.editor-section-stack {
  gap: 1.2rem;
}

.editor-label-head {
  display: grid;
  gap: 0.35rem;
  min-height: 2rem;
  padding: 0.25rem 0.35rem 0.1rem;
  align-content: start;
  position: relative;
  z-index: 1;
  background: linear-gradient(180deg, rgba(243, 248, 253, 0.96), rgba(243, 248, 253, 0.88));
  border-radius: var(--radius-sm);
}

.editor-label-title {
  color: var(--text-strong);
  font-size: 1rem;
  font-weight: 800;
  line-height: 1.2;
  margin: 0;
}

.editor-collab-note {
  color: var(--brand-blue);
  font-size: 0.82rem;
  font-weight: 600;
  line-height: 1.35;
  min-height: 1.1rem;
}

.field-input,
.entry-textarea,
.editor-textarea {
  width: 100%;
  border: 2px solid rgba(22, 50, 79, 0.48);
  border-radius: var(--radius-md);
  padding: 0.85rem 0.95rem;
  background: #ffffff;
  color: var(--text-strong);
  box-shadow:
    0 10px 22px rgba(22, 50, 79, 0.13),
    inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.field-label > .field-input,
.field-label > .entry-textarea,
.field-label > .editor-textarea,
.field-label > .quill-editor-host {
  pointer-events: auto;
}

.field-input:focus,
.entry-textarea:focus,
.editor-textarea:focus {
  border-color: rgba(20, 67, 112, 0.88);
  box-shadow:
    0 0 0 3px rgba(15, 45, 86, 0.42),
    0 14px 30px rgba(8, 25, 47, 0.26);
  outline: none;
}

.entry-textarea,
.editor-textarea {
  min-height: 130px;
  resize: vertical;
}

.field-label > .field-input,
.field-label > .entry-textarea,
.field-label > .editor-textarea,
.field-label > .quill-editor-host {
  margin-top: 0.1rem;
}

.field-label-heading,
.iep-page-header-meta {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  flex-wrap: wrap;
}

.field-label-heading {
  justify-content: flex-start;
  flex-wrap: nowrap;
  position: relative;
}

.iep-page-header-meta {
  justify-content: space-between;
}

.field-label-heading > span,
.iep-page-header-meta > span {
  min-width: 0;
}

.field-sync-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.18rem 0.55rem;
  border-radius: var(--radius-lg);
  border: 1px solid rgba(22, 50, 79, 0.12);
  background: rgba(225, 238, 250, 0.75);
  color: var(--brand-navy);
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.02em;
  white-space: nowrap;
}

.field-label-heading .field-sync-badge {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
}

.iep-page-header-meta .field-sync-badge {
  flex: 0 0 auto;
}

.field-sync-badge.is-live {
  background: rgba(225, 238, 250, 0.75);
  color: var(--brand-blue);
}

.field-sync-badge.is-syncing {
  background: rgba(255, 239, 190, 0.85);
  color: #8a5c00;
}

.field-sync-badge.is-synced {
  background: rgba(220, 245, 228, 0.92);
  color: #1c6a37;
}

.field-sync-badge.is-rebased {
  background: rgba(255, 226, 228, 0.92);
  color: #a73d48;
}

.quill-editor-host {
  display: grid;
  align-content: start;
  min-width: 0;
  position: relative;
  z-index: 1;
  border-radius: var(--radius-md);
}

.quill-editor-host > div {
  display: grid;
  align-content: start;
  min-width: 0;
}

.narrative-editor-field > .quill-editor-host {
  position: relative;
  z-index: 1;
}

.quill-editor-host .ql-container.ql-snow {
  border: 2px solid rgba(22, 50, 79, 0.48);
  border-top: 0;
  border-radius: 0 0 var(--radius-md) var(--radius-md);
  background: #ffffff;
  color: var(--text-strong);
  font-family: "Aptos", "Segoe UI", sans-serif;
  box-shadow: 0 10px 22px rgba(22, 50, 79, 0.13);
  position: relative;
  z-index: 1;
  height: auto;
  min-height: 190px;
  overflow: hidden;
}

.quill-editor-host .ql-toolbar.ql-snow {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.55rem;
  border: 2px solid rgba(22, 50, 79, 0.48);
  border-bottom: 1px solid rgba(22, 50, 79, 0.18);
  border-radius: var(--radius-md) var(--radius-md) 0 0;
  background: linear-gradient(180deg, #eef6fd 0%, #ddebf7 100%);
  padding: 0.7rem 0.85rem;
  position: relative;
  z-index: 1;
  overflow: hidden;
  transition:
    max-height 160ms ease,
    opacity 140ms ease,
    padding 160ms ease,
    border-color 120ms ease,
    transform 160ms ease;
}

.quill-editor-host .ql-toolbar.ql-snow .ql-formats {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  margin-right: 0;
  white-space: nowrap;
  padding-right: 0.5rem;
  border-right: 1px solid rgba(22, 50, 79, 0.18);
}

.quill-editor-host .ql-toolbar.ql-snow .ql-formats:last-child {
  border-right: 0;
  padding-right: 0;
}

.quill-editor-host .ql-toolbar.ql-snow button,
.quill-editor-host .ql-toolbar.ql-snow .ql-picker {
  flex: 0 0 auto;
}

.quill-editor-host .ql-toolbar.ql-snow button {
  appearance: none;
  width: 28px;
  min-width: 28px;
  max-width: 28px;
  height: 28px;
  min-height: 28px;
  max-height: 28px;
  margin: 0;
  padding: 3px;
  border: 0;
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.62);
  box-shadow: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  vertical-align: middle;
  transition: background-color 120ms ease, box-shadow 120ms ease;
}

.quill-editor-host .ql-toolbar.ql-snow button,
.quill-editor-host .ql-toolbar.ql-snow button:hover,
.quill-editor-host .ql-toolbar.ql-snow button:focus,
.quill-editor-host .ql-toolbar.ql-snow button:focus-visible,
.quill-editor-host .ql-toolbar.ql-snow .ql-picker,
.quill-editor-host .ql-toolbar.ql-snow .ql-picker:hover,
.quill-editor-host .ql-toolbar.ql-snow .ql-picker.ql-expanded,
.quill-editor-host .ql-toolbar.ql-snow .ql-picker-label,
.quill-editor-host .ql-toolbar.ql-snow .ql-picker-label:hover,
.quill-editor-host .ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-label {
  background: rgba(255, 255, 255, 0.62) !important;
  box-shadow: none !important;
  color: #34495f !important;
  outline: none !important;
}

.quill-editor-host .ql-toolbar.ql-snow button .ql-stroke,
.quill-editor-host .ql-toolbar.ql-snow button:hover .ql-stroke,
.quill-editor-host .ql-toolbar.ql-snow button:focus .ql-stroke,
.quill-editor-host .ql-toolbar.ql-snow button:focus-visible .ql-stroke,
.quill-editor-host .ql-toolbar.ql-snow .ql-picker .ql-stroke,
.quill-editor-host .ql-toolbar.ql-snow .ql-picker:hover .ql-stroke,
.quill-editor-host .ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-stroke {
  stroke: #34495f !important;
}

.quill-editor-host .ql-toolbar.ql-snow button .ql-fill,
.quill-editor-host .ql-toolbar.ql-snow button:hover .ql-fill,
.quill-editor-host .ql-toolbar.ql-snow button:focus .ql-fill,
.quill-editor-host .ql-toolbar.ql-snow button:focus-visible .ql-fill,
.quill-editor-host .ql-toolbar.ql-snow .ql-picker .ql-fill,
.quill-editor-host .ql-toolbar.ql-snow .ql-picker:hover .ql-fill,
.quill-editor-host .ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-fill {
  fill: #34495f !important;
}

.quill-editor-host .ql-toolbar.ql-snow button.ql-active,
.quill-editor-host .ql-toolbar.ql-snow button.ql-active:hover,
.quill-editor-host .ql-toolbar.ql-snow button.ql-active:focus,
.quill-editor-host .ql-toolbar.ql-snow button.ql-active:focus-visible {
  background: rgba(40, 103, 158, 0.14) !important;
  box-shadow: inset 0 0 0 1px rgba(15, 45, 86, 0.22) !important;
  color: var(--brand-navy) !important;
}

.quill-editor-host .ql-toolbar.ql-snow button.ql-active .ql-stroke,
.quill-editor-host .ql-toolbar.ql-snow button.ql-active:hover .ql-stroke,
.quill-editor-host .ql-toolbar.ql-snow button.ql-active:focus .ql-stroke,
.quill-editor-host .ql-toolbar.ql-snow button.ql-active:focus-visible .ql-stroke {
  stroke: var(--brand-navy) !important;
}

.quill-editor-host .ql-toolbar.ql-snow button.ql-active .ql-fill,
.quill-editor-host .ql-toolbar.ql-snow button.ql-active:hover .ql-fill,
.quill-editor-host .ql-toolbar.ql-snow button.ql-active:focus .ql-fill,
.quill-editor-host .ql-toolbar.ql-snow button.ql-active:focus-visible .ql-fill {
  fill: var(--brand-navy) !important;
}

.quill-editor-host .ql-toolbar.ql-snow .ql-formats > button + button {
  margin-left: 0;
}

.quill-editor-host .ql-toolbar.ql-snow .ql-picker {
  height: 28px;
  display: inline-flex;
  align-items: center;
}

.quill-editor-host .ql-editor {
  min-height: 150px;
  height: auto;
  padding: 0.85rem 0.95rem;
  font-size: 1rem;
  line-height: 1.5;
  white-space: pre-wrap;
}

.quill-editor-host:hover .ql-toolbar.ql-snow,
.quill-editor-host:hover .ql-container.ql-snow {
  border-color: rgba(15, 45, 86, 0.72);
}

.quill-editor-host:hover .ql-container.ql-snow {
  box-shadow:
    0 14px 26px rgba(8, 25, 47, 0.16),
    inset 0 0 0 1px rgba(15, 45, 86, 0.18);
}

.quill-editor-host .ql-editor img {
  max-width: min(100%, 600px);
  height: auto;
  display: block;
}

.locked-quill-editor-host {
  position: relative;
}

.locked-quill-editor-host .ql-toolbar.ql-snow,
.locked-quill-editor-host .ql-container.ql-snow {
  background: rgba(245, 249, 253, 0.96);
}

.locked-quill-editor-host .ql-toolbar.ql-snow {
  opacity: 0.72;
}

.locked-quill-editor-host .ql-editor {
  cursor: not-allowed;
  opacity: 0.84;
}

.locked-quill-editor-host::after {
  content: attr(data-lock-message);
  position: absolute;
  top: 0.9rem;
  right: 0.9rem;
  z-index: 3;
  padding: 0.25rem 0.55rem;
  border-radius: 999px;
  background: rgba(24, 50, 74, 0.08);
  color: var(--text-muted);
  font-size: 0.76rem;
  font-weight: 700;
  pointer-events: none;
}

.editor-card {
  display: grid;
  gap: 0.45rem;
  padding: 0.95rem;
  border-radius: var(--radius-xl);
  background: var(--surface-panel);
  border: 2px solid rgba(36, 91, 133, 0.2);
  box-shadow:
    0 8px 18px rgba(22, 50, 79, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.68);
}

.workflow-status-grid {
  display: grid;
  gap: 0.75rem;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
}

.workflow-status-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  align-items: start;
  gap: 0.85rem;
  width: 100%;
  padding: 0.8rem 0.9rem;
  border-radius: var(--radius-lg);
  border: 2px solid rgba(36, 91, 133, 0.2);
  background: rgba(255, 255, 255, 0.9);
  box-shadow:
    0 8px 18px rgba(22, 50, 79, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.68);
  text-align: left;
  min-width: 0;
}

.workflow-status-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  justify-items: start;
  gap: 0.45rem;
  min-width: 0;
}

.workflow-status-card.status-complete {
  background: linear-gradient(180deg, rgba(201, 232, 211, 0.98), rgba(224, 242, 231, 0.96));
  border-color: rgba(46, 142, 79, 0.42);
}

.workflow-status-card.status-in-progress,
.workflow-status-card.status-needs-review {
  background: linear-gradient(180deg, rgba(243, 225, 165, 0.98), rgba(250, 237, 194, 0.96));
  border-color: rgba(181, 137, 0, 0.44);
}

.workflow-status-card.status-not-started {
  background: linear-gradient(180deg, rgba(242, 205, 207, 0.98), rgba(250, 225, 227, 0.96));
  border-color: rgba(191, 74, 86, 0.44);
}

.workflow-status-card strong,
.workflow-status-card small {
  display: block;
  margin: 0;
  min-width: 0;
  overflow-wrap: anywhere;
}

.workflow-status-card small {
  color: var(--text-muted);
  margin-top: 0.2rem;
}

.workflow-status-card.is-clickable {
  cursor: pointer;
  transition: transform 120ms ease, box-shadow 120ms ease, background-color 120ms ease;
}

.workflow-status-card.is-clickable:hover,
.workflow-status-card.is-clickable:focus-visible {
  transform: translateY(-1px);
  box-shadow: inset 0 0 0 1px rgba(47, 120, 168, 0.28), 0 10px 22px rgba(22, 50, 79, 0.08);
  outline: none;
}

.workflow-status-copy {
  display: grid;
  gap: 0.3rem;
  min-width: 0;
  width: 100%;
}

.workflow-status-detail {
  margin: 0;
  color: #35526c;
  font-size: 0.9rem;
  line-height: 1.35;
  width: 100%;
  overflow-wrap: anywhere;
  word-break: normal;
}

.workflow-status-notes {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  min-width: 0;
}

.workflow-status-note {
  display: inline-flex;
  align-items: center;
  max-width: 100%;
  padding: 0.22rem 0.5rem;
  border-radius: var(--radius-md);
  background: rgba(199, 233, 255, 0.5);
  color: var(--brand-blue);
  font-size: 0.78rem;
  line-height: 1.2;
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: normal;
  hyphens: none;
}

.workflow-status-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  max-width: 100%;
  min-height: 28px;
  padding: 0.25rem 0.7rem;
  border-radius: var(--radius-lg);
  font-size: 0.75rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  white-space: nowrap;
}

.workflow-status-pill,
.field-sync-badge,
.section-pill,
.info-chip,
.checkbox-row,
.iep-section-nav-button,
.primary-button,
.secondary-button {
  border-radius: var(--radius-md);
}

.workflow-status-pill.required {
  background: rgba(36, 91, 133, 0.1);
  color: var(--brand-blue);
}

.workflow-status-pill.conditional {
  background: rgba(36, 91, 133, 0.1);
  color: var(--brand-blue);
}

.workflow-status-pill.audit {
  background: rgba(36, 91, 133, 0.1);
  color: var(--brand-blue);
}

.workflow-status-card.status-complete {
  box-shadow: inset 0 0 0 1px rgba(89, 173, 114, 0.22);
}

.workflow-status-card.status-in-progress,
.workflow-status-card.status-needs-review {
  box-shadow: inset 0 0 0 1px rgba(212, 173, 36, 0.28);
}

.workflow-status-card.status-not-started {
  box-shadow: inset 0 0 0 1px rgba(215, 111, 104, 0.24);
}

.workflow-status-pill.status-complete {
  background: var(--status-green-bg);
  color: var(--status-green-text);
}

.workflow-status-pill.status-in-progress,
.workflow-status-pill.status-needs-review {
  background: var(--status-yellow-bg);
  color: var(--status-yellow-text);
}

.workflow-status-pill.status-not-started {
  background: var(--status-red-bg);
  color: var(--status-red-text);
}

.editor-compact-card p,
.editor-compact-card small,
.signature-row p,
.signature-row small,
.editor-section-detail {
  margin: 0;
}

.editor-section-card {
  padding: 0.8rem;
  border-radius: var(--radius-2xl);
  background: rgba(247, 251, 255, 0.84);
  box-shadow: inset 0 0 0 1px var(--border-soft);
}

.editor-section-header,
.signature-row {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 0.9rem;
}

.structured-section {
  display: grid;
  gap: 0.9rem;
}

.structured-grid {
  display: grid;
  gap: 0.85rem;
}

.three-column {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.four-column {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.structured-row-card {
  display: grid;
  gap: 0.8rem;
  padding: 0.95rem;
  border-radius: var(--radius-xl);
  background: linear-gradient(180deg, rgba(184, 212, 235, 0.98), rgba(159, 196, 224, 0.96));
  box-shadow:
    0 14px 32px rgba(22, 50, 79, 0.08),
    inset 0 0 0 1px rgba(36, 91, 133, 0.22);
  transition: transform 140ms ease, background 140ms ease, box-shadow 140ms ease;
}

.structured-row-card:hover {
  transform: translateY(-2px);
  background: linear-gradient(180deg, rgba(174, 204, 229, 0.99), rgba(145, 185, 216, 0.98));
  box-shadow:
    0 20px 40px rgba(8, 25, 47, 0.18),
    inset 0 0 0 1px rgba(21, 64, 105, 0.32);
}

.special-consideration-card {
  background:
    linear-gradient(180deg, rgba(236, 244, 252, 0.82), rgba(244, 248, 253, 0.92));
  box-shadow:
    0 10px 24px rgba(22, 50, 79, 0.04),
    inset 0 0 0 1px rgba(36, 91, 133, 0.09);
}

.special-consideration-card .field-label > .field-input,
.special-consideration-card .field-label > .entry-textarea,
.special-consideration-card .field-label > .editor-textarea,
.special-consideration-card .field-label > .quill-editor-host {
  background: rgba(255, 255, 255, 0.96);
}

.structured-row-header {
  display: grid;
  gap: 0.2rem;
}

.checkbox-row {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  min-height: 32px;
  padding: 0.25rem 0.55rem;
  border-radius: var(--radius-lg);
  background: rgba(225, 238, 250, 0.92);
  color: var(--brand-navy);
  font-weight: 600;
}

.editor-section-detail {
  color: #5f6f81;
  line-height: 1.45;
}

.section-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  padding: 0.25rem 0.7rem;
  border-radius: var(--radius-lg);
  font-size: 0.76rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.section-pill.required,
.section-pill.audit {
  background: rgba(199, 233, 255, 0.5);
  color: var(--brand-blue);
}

.section-pill.conditional {
  background: rgba(212, 173, 36, 0.18);
  color: var(--status-yellow-text);
}

.section-pill.blocker {
  background: rgba(187, 79, 79, 0.14);
  color: #934343;
}

.section-pill.state-local {
  background: rgba(82, 120, 166, 0.14);
  color: #365b86;
}

.signature-row {
  padding: 0.9rem 1rem;
  border-radius: var(--radius-xl);
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid var(--border-soft);
}

.iep-form-stack {
  gap: 1.2rem;
}

.iep-page-turn-shell {
  display: grid;
  position: relative;
  overflow: hidden;
  isolation: isolate;
  align-items: start;
  align-content: start;
}

.iep-page-turn-stage {
  grid-area: 1 / 1;
  display: grid;
  gap: 0.85rem;
  position: relative;
  align-self: start;
  width: 100%;
  will-change: transform, opacity, filter;
}

.iep-page-turn-stage:not(:first-child) {
  z-index: 1;
}

.iep-page-step-controls {
  display: grid;
  grid-template-columns: minmax(8.5rem, max-content) minmax(0, 1fr) minmax(8.5rem, max-content);
  align-items: center;
  gap: 0.75rem;
  padding: 0.55rem 0.65rem;
  border: 1px solid rgba(22, 50, 79, 0.08);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 10px 24px rgba(31, 45, 61, 0.05);
}

.iep-page-step-controls.is-bottom {
  margin-top: 0.25rem;
}

.iep-page-step-controls .primary-button,
.iep-page-step-controls .secondary-button {
  min-height: 2.35rem;
  padding: 0.5rem 0.85rem;
  border-radius: var(--radius-md);
  box-shadow: none;
}

.iep-page-step-controls .primary-button:disabled,
.iep-page-step-controls .secondary-button:disabled {
  cursor: not-allowed;
  opacity: 0.46;
}

.iep-page-step-status {
  display: grid;
  gap: 0.12rem;
  justify-items: center;
  min-width: 0;
  color: var(--text-strong);
  text-align: center;
}

.iep-page-step-status strong {
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.iep-page-step-status span {
  color: var(--text-muted);
  font-size: 0.86rem;
  font-weight: 600;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  width: 100%;
}

.iep-page {
  display: grid;
  gap: 0.85rem;
  scroll-margin-top: 8rem;
}

.iep-page-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem;
}

.iep-page-header h3,
.iep-page-header span {
  margin: 0;
}

.iep-page-header span {
  color: var(--text-muted);
  font-size: 0.9rem;
}

.iep-form-card {
  display: grid;
  gap: 0.9rem;
  padding: 1rem;
  border-radius: var(--radius-2xl);
  background: linear-gradient(180deg, rgba(184, 212, 235, 0.98), rgba(159, 196, 224, 0.96));
  box-shadow:
    0 18px 40px rgba(22, 50, 79, 0.12),
    inset 0 0 0 1px rgba(36, 91, 133, 0.22);
}

.iep-document-control-card {
  gap: 0.8rem;
  padding: 1rem;
  border-radius: var(--radius-xl);
  background: linear-gradient(180deg, rgba(236, 246, 255, 0.98), rgba(211, 231, 247, 0.96));
  color: var(--text-strong);
  font-size: 0.92rem;
  box-shadow:
    0 16px 34px rgba(22, 50, 79, 0.12),
    inset 0 0 0 1px rgba(36, 91, 133, 0.2);
}

.iep-document-title-bar {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.85rem 1rem;
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.76);
  color: var(--brand-navy);
  box-shadow: inset 0 0 0 1px rgba(36, 91, 133, 0.14);
  line-height: 1.2;
}

.iep-document-title-bar strong {
  font-size: 1rem;
  font-weight: 800;
}

.iep-document-title-bar span {
  color: var(--text-muted);
  font-size: 0.84rem;
  font-weight: 700;
  white-space: nowrap;
}

.iep-document-section-heading {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  margin-top: 0.2rem;
  color: var(--brand-navy);
  font-size: 0.84rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.iep-document-section-heading::after {
  content: "";
  height: 1px;
  flex: 1;
  background: rgba(36, 91, 133, 0.18);
}

.iep-document-control-card .structured-grid {
  gap: 0.55rem 1rem;
  padding: 0.8rem;
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.5);
  box-shadow: inset 0 0 0 1px rgba(36, 91, 133, 0.11);
}

.iep-document-control-card .structured-grid.four-column {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.iep-document-control-card .field-label {
  grid-template-columns: minmax(9rem, max-content) minmax(0, 1fr);
  align-items: center;
  gap: 0.5rem;
  min-height: 2.1rem;
}

.iep-document-control-card .field-label > span,
.iep-document-control-card .compact-grid .field-label > span {
  display: block;
  min-height: 0;
  color: var(--brand-navy);
  font-size: 0.82rem;
  font-weight: 700;
  line-height: 1.2;
}

.iep-document-control-card .field-input,
.iep-document-control-card .quill-editor-host .ql-container.ql-snow {
  border: 0;
  border-bottom: 1px solid rgba(36, 91, 133, 0.38);
  border-radius: var(--radius-xs) var(--radius-xs) 0 0;
  background: rgba(255, 255, 255, 0.24);
  box-shadow: none;
  color: var(--text-strong);
}

.iep-document-control-card .field-input {
  min-height: 2rem;
  padding: 0.32rem 0.42rem 0.24rem;
  line-height: 1.2;
}

.iep-document-control-card select.field-input {
  appearance: auto;
}

.iep-document-control-card .quill-editor-host {
  min-height: 2rem;
  border-radius: var(--radius-xs);
}

.iep-document-control-card .quill-editor-host .ql-container.ql-snow {
  min-height: 2rem;
  overflow: visible;
}

.iep-document-control-card .quill-editor-host .ql-editor {
  min-height: 2rem;
  padding: 0.32rem 0.42rem 0.24rem;
  font-size: 0.92rem;
  line-height: 1.25;
}

.iep-document-control-card .single-line-quill-editor-host .ql-container.ql-snow,
.iep-document-control-card .single-line-quill-editor-host .ql-editor {
  min-height: 2rem;
}

.iep-document-control-card .field-input:hover,
.iep-document-control-card .quill-editor-host:hover .ql-container.ql-snow {
  background: rgba(218, 235, 248, 0.38);
  border-bottom-color: var(--brand-blue);
}

.iep-document-control-card .field-input:focus,
.iep-document-control-card .quill-editor-host:focus-within .ql-container.ql-snow {
  border: 1px solid rgba(20, 67, 112, 0.88);
  border-radius: var(--radius-xs);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(47, 120, 168, 0.18);
}

.iep-document-control-card > .field-label {
  grid-template-columns: minmax(13rem, max-content) minmax(0, 1fr);
  padding: 0.8rem;
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.5);
  box-shadow: inset 0 0 0 1px rgba(36, 91, 133, 0.11);
}

.iep-document-control-card > .field-label .quill-editor-host .ql-container.ql-snow,
.iep-document-control-card > .field-label .quill-editor-host .ql-editor {
  min-height: 3.2rem;
}

.iep-revision-note {
  color: var(--text-muted);
  font-size: 0.84rem;
  line-height: 1.25;
}

.iep-revision-table {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  overflow: hidden;
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.55);
  color: var(--text-strong);
  font-size: 0.82rem;
  box-shadow: inset 0 0 0 1px rgba(36, 91, 133, 0.18);
}

.iep-revision-table > div,
.iep-revision-table > label {
  min-height: 2.1rem;
  margin: 0;
  padding: 0.35rem 0.55rem;
  border-right: 1px solid rgba(36, 91, 133, 0.16);
  border-bottom: 1px solid rgba(36, 91, 133, 0.16);
}

.iep-revision-table > div:nth-child(-n + 3) {
  text-align: center;
  font-weight: 800;
}

.iep-revision-table .field-label {
  display: block;
}

.iep-revision-table .field-input {
  border-bottom: 0;
  text-align: center;
}

.iep-form-stack.is-section-workspace .iep-page.is-inactive {
  display: none;
}

.iep-form-stack.is-section-workspace .iep-page.is-active {
  display: grid;
}

.iep-section-nav {
  position: sticky;
  top: 0;
  z-index: 6;
  display: block;
  padding: 0;
  border-radius: var(--radius-xl);
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
  overflow: visible;
}

.iep-section-nav[open] {
  z-index: 12;
}

.iep-section-nav-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  cursor: pointer;
  list-style: none;
  padding: 0.7rem 0.85rem;
  border-radius: var(--radius-xl);
  background: linear-gradient(135deg, rgba(26, 69, 122, 0.96), rgba(18, 52, 95, 0.98));
  box-shadow:
    0 12px 28px rgba(22, 50, 79, 0.07),
    inset 0 0 0 1px rgba(163, 201, 240, 0.2);
  backdrop-filter: blur(12px);
}

.iep-section-nav-header::-webkit-details-marker {
  display: none;
}

.iep-section-nav-header strong,
.iep-section-nav-header span {
  margin: 0;
}

.iep-section-nav-title-group {
  display: grid;
  gap: 0.12rem;
  min-width: 0;
  flex: 1 1 auto;
}

.iep-section-nav-header strong {
  font-size: 1rem;
  color: #f7fbff;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.iep-section-nav-title-group small {
  color: rgba(223, 236, 250, 0.78);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.iep-section-nav-header span {
  color: rgba(223, 236, 250, 0.88);
  font-size: 0.8rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.iep-section-nav-plus {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.6rem;
  height: 1.6rem;
  padding: 0.28rem;
  border-radius: var(--radius-lg);
  background: rgba(217, 236, 255, 0.18);
  color: #f7fbff;
  flex: 0 0 auto;
  transition: transform 140ms ease, background 140ms ease;
}

.iep-section-nav[open] .iep-section-nav-plus {
  transform: rotate(45deg);
  background: rgba(217, 236, 255, 0.24);
}

.iep-section-nav-list {
  position: absolute;
  top: calc(100% + 0.55rem);
  left: 0;
  right: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  padding: 0.8rem;
  border-radius: var(--radius-xl);
  background: linear-gradient(145deg, rgba(22, 60, 108, 0.98), rgba(15, 45, 86, 0.99));
  box-shadow:
    0 18px 40px rgba(42, 33, 25, 0.12),
    inset 0 0 0 1px rgba(173, 209, 245, 0.18);
  backdrop-filter: blur(14px);
}

.iep-section-nav-button {
  display: grid;
  align-items: center;
  justify-content: center;
  gap: 0.12rem;
  min-height: 2.2rem;
  padding: 0.45rem 0.75rem;
  border: 1px solid rgba(173, 209, 245, 0.16);
  border-radius: var(--radius-lg);
  background: rgba(236, 245, 255, 0.12);
  color: #f7fbff;
  cursor: pointer;
  text-align: center;
  transition:
    transform 160ms ease,
    box-shadow 160ms ease,
    border-color 160ms ease,
    background 160ms ease;
}

.iep-section-nav-button:hover,
.iep-section-nav-button:focus-visible,
.iep-section-nav-button.is-active {
  transform: translateY(-1px);
  border-color: rgba(198, 226, 252, 0.34);
  background: rgba(236, 245, 255, 0.2);
  box-shadow: 0 6px 14px rgba(8, 25, 47, 0.22);
  outline: none;
}

.iep-section-nav-button.is-active {
  background: rgba(236, 245, 255, 0.28);
  border-color: rgba(198, 226, 252, 0.5);
}

.iep-section-nav-button strong {
  color: rgba(247, 251, 255, 0.82);
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  line-height: 1.1;
  text-transform: uppercase;
}

.iep-section-nav-button span {
  font-size: 0.86rem;
  font-weight: 700;
  line-height: 1.15;
}

.iep-form-table-block {
  display: grid;
  gap: 0.75rem;
  margin-top: 0.85rem;
}

.iep-form-table-title {
  font-weight: 800;
  color: var(--brand-navy);
}

.iep-grid-table {
  display: grid;
  gap: 0.2rem;
}

.iep-grid-table-scroll {
  overflow-x: auto;
  padding-bottom: 0.2rem;
}

.iep-grid-table-scroll .iep-grid-table {
  min-width: max-content;
}

.iep-grid-row {
  display: grid;
  gap: 0.5rem;
  padding: 0.7rem;
  border-radius: var(--radius-md);
  background: rgba(232, 242, 251, 0.96);
  box-shadow: inset 0 0 0 1px rgba(36, 91, 133, 0.22);
}

.iep-grid-header {
  background: linear-gradient(180deg, rgba(225, 238, 250, 0.96), rgba(208, 226, 241, 0.9));
  color: var(--brand-navy);
  font-weight: 700;
}

.iep-signature-grid {
  grid-template-columns: 1.2fr 1fr 1.2fr;
}

.iep-signature-cell {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

.iep-grid-cell {
  min-width: 0;
}

.iep-grid-cell .field-input,
.iep-grid-cell select.field-input {
  min-width: 100%;
}

.iep-team-card {
  gap: 1rem;
}

.iep-team-card .field-input,
.iep-team-card .quill-editor-host .ql-container.ql-snow {
  border: 0;
  border-bottom: 1px solid rgba(36, 91, 133, 0.38);
  border-radius: var(--radius-xs) var(--radius-xs) 0 0;
  background: rgba(255, 255, 255, 0.18);
  box-shadow: none;
  color: var(--text-strong);
}

.iep-team-card .field-input {
  min-height: 2rem;
  padding: 0.32rem 0.42rem 0.24rem;
}

.iep-team-card .quill-editor-host {
  min-height: 2rem;
  border-radius: var(--radius-xs);
  box-shadow: none;
}

.iep-team-card .toolbar-hidden-quill-editor-host .ql-container.ql-snow,
.iep-team-card .single-line-quill-editor-host .ql-container.ql-snow {
  min-height: 2rem;
  border-top: 0;
  border-radius: var(--radius-xs) var(--radius-xs) 0 0;
}

.iep-team-card .single-line-quill-editor-host .ql-editor,
.iep-team-card .quill-editor-host .ql-editor {
  min-height: 2rem;
  padding: 0.32rem 0.42rem 0.24rem;
  font-size: 0.92rem;
  line-height: 1.25;
}

.iep-team-card .field-input:hover,
.iep-team-card .quill-editor-host:hover .ql-container.ql-snow {
  background: rgba(255, 255, 255, 0.36);
  border-bottom-color: var(--brand-blue);
}

.iep-team-card .field-input:focus,
.iep-team-card .quill-editor-host:focus-within .ql-container.ql-snow {
  border: 1px solid rgba(20, 67, 112, 0.88);
  border-radius: var(--radius-xs);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(47, 120, 168, 0.18);
}

.iep-team-card .quill-editor-host:focus-within {
  box-shadow: none;
}

.iep-team-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.9rem 1rem;
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.68);
  box-shadow: inset 0 0 0 1px rgba(36, 91, 133, 0.14);
}

.iep-team-toolbar > div {
  display: grid;
  gap: 0.18rem;
}

.iep-team-toolbar strong {
  color: var(--brand-navy);
  font-size: 1rem;
}

.iep-team-toolbar span {
  color: var(--text-muted);
  font-size: 0.86rem;
}

.iep-team-roster {
  display: grid;
  gap: 0.25rem;
  padding-bottom: 0.2rem;
}

.iep-team-list-header,
.iep-team-member-main {
  display: grid;
  grid-template-columns: minmax(10rem, 1.05fr) minmax(10rem, 1.05fr) minmax(13rem, 1.25fr) minmax(6rem, 0.45fr);
  gap: 0.55rem;
  align-items: center;
}

.iep-team-list-header {
  padding: 0.65rem 0.75rem;
  border-radius: var(--radius-md) var(--radius-md) 0 0;
  background: rgba(255, 255, 255, 0.62);
  color: var(--brand-navy);
  font-size: 0.82rem;
  font-weight: 800;
}

.iep-team-list-header span:nth-child(n + 5) {
  display: none;
}

.iep-team-member-card {
  display: grid;
  gap: 0;
  padding: 0;
  border-radius: var(--radius-xs);
  background: rgba(255, 255, 255, 0.34);
  box-shadow: inset 0 -1px 0 rgba(36, 91, 133, 0.13);
}

.iep-team-member-main {
  grid-template-areas:
    "role name signature actions"
    "email phone attendance input";
  grid-template-rows: auto auto;
  padding: 0.65rem 0.75rem;
}

.iep-team-member-main > .field-label,
.iep-team-attendance .field-label {
  gap: 0.28rem;
}

.iep-team-member-main > .field-label:nth-child(1) {
  grid-area: role;
}

.iep-team-member-main > .field-label:nth-child(2) {
  grid-area: name;
}

.iep-team-member-main > .field-label:nth-child(5) {
  grid-area: email;
}

.iep-team-member-main > .field-label:nth-child(6) {
  grid-area: phone;
}

.iep-team-member-main > .field-label:nth-child(7) {
  grid-area: attendance;
}

.iep-team-member-main > .field-label:nth-child(8) {
  grid-area: input;
}

.iep-team-member-main > .field-label:nth-child(7) .field-input,
.iep-team-member-main > .field-label:nth-child(8) .field-input {
  min-width: 100%;
}

.iep-team-member-main > .field-label > span {
  color: var(--text-muted);
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
}

.iep-team-attendance {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 0.35rem;
}

.iep-team-signature {
  grid-area: signature;
  display: grid;
  grid-template-columns: auto auto;
  align-items: center;
  gap: 0.35rem 0.55rem;
}

.iep-team-signature small {
  grid-column: 1 / -1;
  color: var(--text-muted);
  font-size: 0.78rem;
}

.iep-team-row-actions {
  grid-area: actions;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.45rem;
}

.iep-team-add-row {
  display: flex;
  justify-content: flex-start;
  padding: 0.75rem 0.25rem 0.25rem;
}

.iep-team-signature .primary-button,
.iep-team-signature .secondary-button,
.iep-team-row-actions .icon-button {
  min-height: 2.25rem;
}

.iep-team-signature .secondary-button {
  background: transparent;
}

.signature-status-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 1.85rem;
  padding: 0.25rem 0.65rem;
  border-radius: var(--radius-lg);
  font-size: 0.8rem;
  font-weight: 800;
}

.signature-status-pill.is-received {
  background: var(--status-green-bg);
  color: var(--status-green-text);
}

.signature-status-pill.is-pending {
  background: var(--status-yellow-bg);
  color: var(--status-yellow-text);
}

.iep-team-notes .field-label {
  display: grid;
  grid-template-columns: minmax(12rem, max-content) minmax(0, 1fr);
  align-items: start;
  padding: 0.2rem 0.75rem 0.75rem;
}

.iep-team-notes {
  border-top: 1px solid rgba(36, 91, 133, 0.09);
}

.iep-team-notes summary {
  width: max-content;
  margin: 0 0.75rem 0.65rem;
  padding-top: 0.42rem;
  cursor: pointer;
  color: var(--brand-blue);
  font-size: 0.86rem;
  font-weight: 800;
}

.iep-team-notes summary:focus-visible {
  outline: 3px solid rgba(47, 120, 168, 0.24);
  outline-offset: 3px;
  border-radius: var(--radius-xs);
}

.rich-row-card {
  display: grid;
  gap: 0.9rem;
  padding: 0.9rem;
  border-radius: var(--radius-xl);
  background: linear-gradient(180deg, rgba(184, 212, 235, 0.98), rgba(159, 196, 224, 0.96));
  box-shadow:
    0 18px 40px rgba(22, 50, 79, 0.1),
    inset 0 0 0 1px rgba(36, 91, 133, 0.24);
  transition: transform 140ms ease, background 140ms ease, box-shadow 140ms ease;
}

.rich-row-card:hover {
  transform: translateY(-2px);
  background: linear-gradient(180deg, rgba(174, 204, 229, 0.99), rgba(145, 185, 216, 0.98));
  box-shadow:
    0 22px 44px rgba(8, 25, 47, 0.2),
    inset 0 0 0 1px rgba(21, 64, 105, 0.34);
}

.rich-row-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  min-height: 44px;
}

.rich-row-card-header > span {
  color: var(--brand-navy);
  font-weight: 800;
}

.compact-row-stack {
  gap: 0.7rem;
}

.service-row-card {
  gap: 0.7rem;
  padding: 0.75rem;
}

.rich-row-primary-field {
  gap: 0.5rem;
}

.rich-row-secondary-grid {
  display: grid;
  gap: 0.85rem;
}

.compact-rich-field {
  gap: 0.35rem;
}

.card-quill-editor-host .ql-editor {
  min-height: 120px;
}

.compact-quill-editor-host .ql-toolbar.ql-snow {
  gap: 0.35rem;
  padding: 0.5rem 0.65rem;
}

.compact-quill-editor-host .ql-toolbar.ql-snow .ql-formats {
  gap: 0.25rem;
}

.compact-quill-editor-host .ql-container.ql-snow {
  min-height: 88px;
}

.compact-quill-editor-host .ql-editor {
  min-height: 62px;
  padding: 0.65rem 0.75rem;
  font-size: 0.95rem;
}

.toolbar-hidden-quill-editor-host .ql-container.ql-snow {
  border-top: 2px solid rgba(22, 50, 79, 0.48);
  border-radius: var(--radius-md);
  min-height: 56px;
}

.quill-editor-host:not(.toolbar-hidden-quill-editor-host) .ql-toolbar.ql-snow {
  max-height: 0;
  padding-top: 0;
  padding-bottom: 0;
  border-top-width: 0;
  border-bottom-width: 0;
  opacity: 0;
  pointer-events: none;
  transform: translateY(-4px);
}

.quill-editor-host:not(.toolbar-hidden-quill-editor-host) .ql-container.ql-snow {
  border-top: 2px solid rgba(22, 50, 79, 0.48);
  border-radius: var(--radius-md);
  transition:
    border-color 120ms ease,
    border-radius 160ms ease,
    box-shadow 120ms ease;
}

.quill-editor-host:not(.toolbar-hidden-quill-editor-host):focus-within .ql-toolbar.ql-snow {
  max-height: 74px;
  padding-top: 0.7rem;
  padding-bottom: 0.7rem;
  border-top-width: 2px;
  opacity: 1;
  pointer-events: auto;
  transform: none;
}

.compact-quill-editor-host:not(.toolbar-hidden-quill-editor-host):focus-within .ql-toolbar.ql-snow {
  max-height: 62px;
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
}

.quill-editor-host:not(.toolbar-hidden-quill-editor-host):focus-within .ql-container.ql-snow {
  border-top: 0;
  border-radius: 0 0 var(--radius-md) var(--radius-md);
}

.quill-editor-host:focus-within .ql-container.ql-snow,
.quill-editor-host:focus-within .ql-toolbar.ql-snow {
  border-color: rgba(20, 67, 112, 0.88);
}

.quill-editor-host:focus-within {
  box-shadow:
    0 0 0 3px rgba(15, 45, 86, 0.42),
    0 14px 30px rgba(8, 25, 47, 0.26);
}

.quill-editor-host:focus-within .ql-container.ql-snow {
  box-shadow: none;
}

.single-line-quill-editor-host .ql-container.ql-snow {
  min-height: 52px;
}

.single-line-quill-editor-host .ql-editor {
  min-height: 52px;
  padding: 0.7rem 0.85rem;
  white-space: normal;
  overflow-x: hidden;
  overflow-y: hidden;
  word-break: break-word;
}

.single-line-quill-editor-host .ql-editor p {
  margin: 0;
}

.iep-team-card .toolbar-hidden-quill-editor-host .ql-container.ql-snow,
.iep-team-card .single-line-quill-editor-host .ql-container.ql-snow,
.iep-team-card .compact-quill-editor-host .ql-container.ql-snow {
  min-height: 2rem;
  border-top: 0;
  border-radius: var(--radius-xs) var(--radius-xs) 0 0;
}

.iep-team-card .single-line-quill-editor-host .ql-editor,
.iep-team-card .compact-quill-editor-host .ql-editor {
  min-height: 2rem;
  padding: 0.32rem 0.42rem 0.24rem;
}

.iep-team-card .quill-editor-host:focus-within {
  box-shadow: none;
}

.iep-team-card .quill-editor-host:focus-within .ql-container.ql-snow {
  border: 1px solid rgba(20, 67, 112, 0.88);
  border-radius: var(--radius-xs);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(47, 120, 168, 0.18);
}

.iep-team-notes .compact-quill-editor-host .ql-container.ql-snow,
.iep-team-notes .compact-quill-editor-host .ql-editor {
  min-height: 3.3rem;
}

.present-levels-input-list {
  display: grid;
  gap: 0.75rem;
  padding: 0.8rem;
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.5);
  box-shadow: inset 0 0 0 1px rgba(36, 91, 133, 0.11);
}

.present-levels-input-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem;
  color: var(--brand-navy);
}

.present-levels-input-header span {
  color: var(--text-muted);
  font-size: 0.84rem;
}

.present-levels-input-card {
  display: grid;
  gap: 0.75rem;
  position: relative;
  padding: 0.8rem;
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, 0.58);
  box-shadow: inset 0 0 0 1px rgba(36, 91, 133, 0.12);
}

.present-levels-input-card-actions {
  display: flex;
  justify-content: flex-end;
  position: absolute;
  right: 0.8rem;
  top: 0.8rem;
  z-index: 1;
}

.present-levels-remove-input {
  min-height: 2.2rem;
  padding-inline: 0.7rem;
}

.iep-document-control-card .toolbar-hidden-quill-editor-host .ql-container.ql-snow,
.iep-document-control-card .single-line-quill-editor-host .ql-container.ql-snow {
  min-height: 2rem;
  border-top: 0;
  border-radius: var(--radius-xs) var(--radius-xs) 0 0;
}

.iep-document-control-card .single-line-quill-editor-host .ql-editor {
  min-height: 2rem;
  padding: 0.32rem 0.42rem 0.24rem;
}

.iep-document-control-card .quill-editor-host:focus-within {
  box-shadow: none;
}

.iep-document-control-card .quill-editor-host:focus-within .ql-container.ql-snow {
  border: 1px solid rgba(20, 67, 112, 0.88);
  border-radius: var(--radius-xs);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(47, 120, 168, 0.18);
}

.live-state-card {
  display: grid;
  gap: 0.9rem;
  grid-template-rows: auto minmax(4.75rem, 4.75rem);
}

.editor-status-block {
  display: grid;
  gap: 0.3rem;
  height: 4.75rem;
  min-height: 4.75rem;
  max-height: 4.75rem;
  padding-top: 0.2rem;
  overflow: hidden;
  align-content: start;
}

.editor-status-label {
  color: #67798d;
  font-weight: 600;
}

.editor-status-value {
  margin: 0;
  line-height: 1.45;
  min-height: 0;
  overflow: auto;
  padding-right: 0.15rem;
  scrollbar-width: thin;
}

.primary-button,
.secondary-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0.7rem 1rem;
  border-radius: var(--radius-lg);
  border: 0;
  cursor: pointer;
}

.hero-card,
.student-hero,
.document-accordion,
.editor-section-card,
.iep-form-card,
.panel-shell,
.data-table-shell {
  border-radius: var(--radius-2xl);
}

.primary-button {
  background: linear-gradient(135deg, var(--brand-navy) 0%, var(--brand-blue) 100%);
  color: #f8fbff;
}

.primary-button:disabled,
.secondary-button:disabled {
  cursor: not-allowed;
  opacity: 0.65;
}

.icon-text-button {
  gap: 0.45rem;
}

.inline-error {
  color: #9b2f2a;
  font-weight: 700;
}

.secondary-button {
  background: var(--brand-blue-mist);
  color: var(--brand-navy);
  border: 1px solid rgba(36, 91, 133, 0.14);
}

.danger-button {
  background: #fff0ef;
  border-color: rgba(155, 47, 42, 0.28);
  color: #9b2f2a;
}

.row-action-bar {
  display: flex;
  justify-content: flex-start;
  padding-top: 0.25rem;
}

.add-row-button {
  gap: 0.45rem;
  min-height: 46px;
  padding-inline: 1.15rem;
  box-shadow: 0 12px 24px rgba(22, 50, 79, 0.18);
}

.icon-button {
  width: 44px;
  min-width: 44px;
  padding: 0;
}

.danger-icon-button {
  color: #8f2e2e;
  background: rgba(255, 239, 239, 0.86);
  border-color: rgba(143, 46, 46, 0.22);
}

.danger-action-button {
  gap: 0.4rem;
  min-height: 2.25rem;
  padding: 0.45rem 0.65rem;
  color: #8f2e2e;
  background: rgba(255, 239, 239, 0.86);
  border: 1px solid rgba(143, 46, 46, 0.22);
}

.text-link {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
}

.students-admin-page {
  display: grid;
  gap: 1rem;
}

.students-admin-page header {
  margin-bottom: 0.35rem !important;
}

.students-admin-page section {
  padding: 1rem 1.1rem !important;
  border-radius: 12px !important;
  border: 1px solid rgba(22, 50, 79, 0.08);
  box-shadow: 0 12px 30px rgba(31, 45, 61, 0.06) !important;
}

.students-admin-page section > div:first-child {
  margin-bottom: 0.8rem !important;
}

.students-admin-page .filter-row {
  align-items: flex-end;
  gap: 0.75rem;
}

.students-admin-page .field-label {
  gap: 0.35rem;
}

.students-admin-page .field-label > span {
  font-size: 0.86rem;
}

.students-admin-page .roster-filter-row .field-label:first-child {
  width: min(320px, 100%);
}

.students-admin-page .roster-filter-row .field-label:last-child {
  width: 130px;
}

.students-admin-page .assignment-control-row .field-label {
  width: min(300px, 100%);
}

.students-admin-page .field-input,
.students-admin-page .primary-button,
.students-admin-page .secondary-button {
  min-height: 38px;
  border-radius: 8px;
  box-shadow: none;
}

.students-admin-page .field-input {
  border: 1px solid rgba(22, 50, 79, 0.28);
  padding: 0.55rem 0.75rem;
  background: rgba(255, 255, 255, 0.96);
}

.students-admin-page .field-input:focus {
  border-color: rgba(36, 91, 133, 0.82);
  box-shadow: 0 0 0 3px rgba(47, 120, 168, 0.16);
}

.students-admin-page .primary-button,
.students-admin-page .secondary-button {
  padding: 0.55rem 0.85rem;
}

.students-admin-page .primary-button {
  background: var(--brand-navy);
}

.students-admin-page .secondary-button {
  background: rgba(223, 239, 252, 0.74);
  border-color: rgba(36, 91, 133, 0.18);
}

.students-admin-page .student-assignment-actions {
  gap: 0.55rem;
}

.students-admin-page p {
  margin: 0;
  color: #35526c;
}

.student-roster-table {
  overflow: hidden;
  border-radius: 12px;
  border: 1px solid rgba(22, 50, 79, 0.08);
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 12px 30px rgba(31, 45, 61, 0.06);
}

.student-roster-table > div {
  border-radius: 12px !important;
  box-shadow: none !important;
}

.student-roster-table table {
  font-size: 0.95rem;
}

.student-roster-table th,
.student-roster-table td {
  padding: 0.85rem 1rem !important;
}

.student-roster-table .field-input {
  width: min(260px, 100%);
}

.student-roster-table input[type="checkbox"] {
  width: 0.95rem;
  height: 0.95rem;
  accent-color: var(--brand-blue);
}

@media (max-width: 900px) {
  .hero-card,
  .student-hero,
  .three-column,
  .rich-row-secondary-grid {
    grid-template-columns: 1fr;
  }

  .iep-section-nav {
    position: static;
  }

  .iep-section-nav-header {
    display: grid;
    justify-content: flex-start;
  }

  .iep-section-nav-header span {
    justify-self: flex-start;
  }

  .iep-section-nav-list {
    position: static;
    margin-top: 0.55rem;
  }

  .iep-section-nav-button {
    min-width: auto;
  }

  .iep-page-step-controls {
    grid-template-columns: 1fr 1fr;
  }

  .iep-page-step-status {
    grid-column: 1 / -1;
    grid-row: 1;
  }

  .iep-page-step-controls .secondary-button {
    grid-column: 1;
    grid-row: 2;
  }

  .iep-page-step-controls .primary-button {
    grid-column: 2;
    grid-row: 2;
  }

  .workflow-status-card {
    grid-template-columns: 1fr;
  }

  .workflow-status-pill {
    justify-self: start;
  }

  .iep-team-toolbar {
    align-items: stretch;
    flex-direction: column;
  }

  .iep-team-member-main,
  .iep-team-notes .field-label {
    grid-template-columns: 1fr;
  }

  .iep-team-member-main .icon-button {
    justify-self: start;
  }

  .iep-document-control-card {
    padding: 0.9rem;
  }

  .iep-document-title-bar {
    font-size: 0.86rem;
  }

  .iep-document-control-card .field-label,
  .iep-document-control-card > .field-label {
    grid-template-columns: 1fr;
    gap: 0.2rem;
  }

  .iep-revision-table {
    grid-template-columns: 1fr;
  }

  .iep-revision-table > div:nth-child(-n + 3) {
    text-align: left;
  }
}
