:root{--react-pdf-annotation-layer: 1;--annotation-unfocused-field-background: url("data:image/svg+xml;charset=UTF-8,<svg width='1px' height='1px' xmlns='http://www.w3.org/2000/svg'><rect width='100%' height='100%' style='fill:rgba(0, 54, 255, 0.13);'/></svg>");--input-focus-border-color: Highlight;--input-focus-outline: 1px solid Canvas;--input-unfocused-border-color: transparent;--input-disabled-border-color: transparent;--input-hover-border-color: black;--link-outline: none}@media screen and (forced-colors:active){:root{--input-focus-border-color: CanvasText;--input-unfocused-border-color: ActiveText;--input-disabled-border-color: GrayText;--input-hover-border-color: Highlight;--link-outline: 1.5px solid LinkText}.annotationLayer .textWidgetAnnotation :is(input,textarea):required,.annotationLayer .choiceWidgetAnnotation select:required,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:required{outline:1.5px solid selectedItem}.annotationLayer .linkAnnotation:hover{-webkit-backdrop-filter:invert(100%);backdrop-filter:invert(100%)}}.annotationLayer{position:absolute;top:0;left:0;pointer-events:none;transform-origin:0 0;z-index:3}.annotationLayer[data-main-rotation="90"] .norotate{transform:rotate(270deg) translate(-100%)}.annotationLayer[data-main-rotation="180"] .norotate{transform:rotate(180deg) translate(-100%,-100%)}.annotationLayer[data-main-rotation="270"] .norotate{transform:rotate(90deg) translateY(-100%)}.annotationLayer canvas{position:absolute;width:100%;height:100%}.annotationLayer section{position:absolute;text-align:initial;pointer-events:auto;box-sizing:border-box;margin:0;transform-origin:0 0}.annotationLayer .linkAnnotation{outline:var(--link-outline)}.textLayer.selecting~.annotationLayer section{pointer-events:none}.annotationLayer :is(.linkAnnotation,.buttonWidgetAnnotation.pushButton)>a{position:absolute;font-size:1em;top:0;left:0;width:100%;height:100%}.annotationLayer :is(.linkAnnotation,.buttonWidgetAnnotation.pushButton)>a:hover{opacity:.2;background:#ff0;box-shadow:0 2px 10px #ff0}.annotationLayer .textAnnotation img{position:absolute;cursor:pointer;width:100%;height:100%;top:0;left:0}.annotationLayer .textWidgetAnnotation :is(input,textarea),.annotationLayer .choiceWidgetAnnotation select,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input{background-image:var(--annotation-unfocused-field-background);border:2px solid var(--input-unfocused-border-color);box-sizing:border-box;font:calc(9px * var(--total-scale-factor)) sans-serif;height:100%;margin:0;vertical-align:top;width:100%}.annotationLayer .textWidgetAnnotation :is(input,textarea):required,.annotationLayer .choiceWidgetAnnotation select:required,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:required{outline:1.5px solid red}.annotationLayer .choiceWidgetAnnotation select option{padding:0}.annotationLayer .buttonWidgetAnnotation.radioButton input{border-radius:50%}.annotationLayer .textWidgetAnnotation textarea{resize:none}.annotationLayer .textWidgetAnnotation :is(input,textarea)[disabled],.annotationLayer .choiceWidgetAnnotation select[disabled],.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input[disabled]{background:none;border:2px solid var(--input-disabled-border-color);cursor:not-allowed}.annotationLayer .textWidgetAnnotation :is(input,textarea):hover,.annotationLayer .choiceWidgetAnnotation select:hover,.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:hover{border:2px solid var(--input-hover-border-color)}.annotationLayer .textWidgetAnnotation :is(input,textarea):hover,.annotationLayer .choiceWidgetAnnotation select:hover,.annotationLayer .buttonWidgetAnnotation.checkBox input:hover{border-radius:2px}.annotationLayer .textWidgetAnnotation :is(input,textarea):focus,.annotationLayer .choiceWidgetAnnotation select:focus{background:none;border:2px solid var(--input-focus-border-color);border-radius:2px;outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) :focus{background-image:none;background-color:transparent}.annotationLayer .buttonWidgetAnnotation.checkBox :focus{border:2px solid var(--input-focus-border-color);border-radius:2px;outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation.radioButton :focus{border:2px solid var(--input-focus-border-color);outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before,.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after,.annotationLayer .buttonWidgetAnnotation.radioButton input:checked:before{background-color:CanvasText;content:"";display:block;position:absolute}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before,.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after{height:80%;left:45%;width:1px}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before{transform:rotate(45deg)}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after{transform:rotate(-45deg)}.annotationLayer .buttonWidgetAnnotation.radioButton input:checked:before{border-radius:50%;height:50%;left:30%;top:20%;width:50%}.annotationLayer .textWidgetAnnotation input.comb{font-family:monospace;padding-left:2px;padding-right:0}.annotationLayer .textWidgetAnnotation input.comb:focus{width:103%}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input{appearance:none}.annotationLayer .popupTriggerArea{height:100%;width:100%}.annotationLayer .fileAttachmentAnnotation .popupTriggerArea{position:absolute}.annotationLayer .popupWrapper{position:absolute;font-size:calc(9px * var(--total-scale-factor));width:100%;min-width:calc(180px * var(--total-scale-factor));pointer-events:none}.annotationLayer .popup{position:absolute;max-width:calc(180px * var(--total-scale-factor));background-color:#ff9;box-shadow:0 calc(2px * var(--total-scale-factor)) calc(5px * var(--total-scale-factor)) #888;border-radius:calc(2px * var(--total-scale-factor));padding:calc(6px * var(--total-scale-factor));margin-left:calc(5px * var(--total-scale-factor));cursor:pointer;font:message-box;white-space:normal;word-wrap:break-word;pointer-events:auto}.annotationLayer .popup>*{font-size:calc(9px * var(--total-scale-factor))}.annotationLayer .popup h1{display:inline-block}.annotationLayer .popupDate{display:inline-block;margin-left:calc(5px * var(--total-scale-factor))}.annotationLayer .popupContent{border-top:1px solid rgba(51,51,51,1);margin-top:calc(2px * var(--total-scale-factor));padding-top:calc(2px * var(--total-scale-factor))}.annotationLayer .richText>*{white-space:pre-wrap;font-size:calc(9px * var(--total-scale-factor))}.annotationLayer .highlightAnnotation,.annotationLayer .underlineAnnotation,.annotationLayer .squigglyAnnotation,.annotationLayer .strikeoutAnnotation,.annotationLayer .freeTextAnnotation,.annotationLayer .lineAnnotation svg line,.annotationLayer .squareAnnotation svg rect,.annotationLayer .circleAnnotation svg ellipse,.annotationLayer .polylineAnnotation svg polyline,.annotationLayer .polygonAnnotation svg polygon,.annotationLayer .caretAnnotation,.annotationLayer .inkAnnotation svg polyline,.annotationLayer .stampAnnotation,.annotationLayer .fileAttachmentAnnotation{cursor:pointer}.annotationLayer section svg{position:absolute;width:100%;height:100%;top:0;left:0}.annotationLayer .annotationTextContent{position:absolute;width:100%;height:100%;opacity:0;color:transparent;-webkit-user-select:none;user-select:none;pointer-events:none}.annotationLayer .annotationTextContent span{width:100%;display:inline-block}:root{--react-pdf-text-layer: 1;--highlight-bg-color: rgba(180, 0, 170, 1);--highlight-selected-bg-color: rgba(0, 100, 0, 1)}@media screen and (forced-colors:active){:root{--highlight-bg-color: Highlight;--highlight-selected-bg-color: ButtonText}}[data-main-rotation="90"]{transform:rotate(90deg) translateY(-100%)}[data-main-rotation="180"]{transform:rotate(180deg) translate(-100%,-100%)}[data-main-rotation="270"]{transform:rotate(270deg) translate(-100%)}.textLayer{position:absolute;text-align:initial;inset:0;overflow:hidden;line-height:1;text-size-adjust:none;forced-color-adjust:none;transform-origin:0 0;z-index:2}.textLayer :is(span,br){color:transparent;position:absolute;white-space:pre;cursor:text;margin:0;transform-origin:0 0}.textLayer span.markedContent{top:0;height:0}.textLayer .highlight{margin:-1px;padding:1px;background-color:var(--highlight-bg-color);border-radius:4px}.textLayer .highlight.appended{position:initial}.textLayer .highlight.begin{border-radius:4px 0 0 4px}.textLayer .highlight.end{border-radius:0 4px 4px 0}.textLayer .highlight.middle{border-radius:0}.textLayer .highlight.selected{background-color:var(--highlight-selected-bg-color)}.textLayer br::selection{background:transparent}.textLayer .endOfContent{display:block;position:absolute;inset:100% 0 0;z-index:-1;cursor:default;-webkit-user-select:none;user-select:none}.textLayer.selecting .endOfContent{top:0}.hiddenCanvasElement{position:absolute;top:0;left:0;width:0;height:0;display:none}:root{--color-primary: #d46b3d;--color-primary-light: #e2875e;--color-primary-dark: #b3562c;--color-primary-bg: rgba(212, 107, 61, .08);--color-primary-bg-hover: rgba(212, 107, 61, .14);--color-dark: #f7efe7;--color-dark-soft: #efe2d4;--color-dark-muted: #decbbb;--color-surface: #ffffff;--color-background: #fbf6f1;--color-background-alt: #f3ebe2;--color-text: #342821;--color-text-secondary: #6f5b4e;--color-text-muted: #9d897c;--color-text-inverse: #ffffff;--color-border: #dccbbd;--color-border-light: #eee3d8;--color-error: #c53030;--color-error-bg: #fff5f5;--font-heading: "Outfit", sans-serif;--font-body: "DM Sans", sans-serif;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-pill: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 2px 8px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .1);--shadow-card: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--transition-fast: .15s ease;--transition-base: .25s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font-body);background:var(--color-background);color:var(--color-text);min-height:100vh;min-height:100dvh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:14px;line-height:1.5}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:600;line-height:1.2;color:var(--color-text)}div.app{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}.header{background:#fffbf7f0;color:var(--color-text);padding:0 32px;height:60px;display:flex;align-items:center;gap:40px;position:sticky;top:0;z-index:100;box-shadow:0 8px 24px #7c5c4314;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.header:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--color-primary) 0%,var(--color-primary-light) 50%,transparent 100%)}.header-left{display:flex;align-items:center;gap:12px}.header-left .logo{color:var(--color-text);text-decoration:none;font-family:var(--font-heading);font-size:18px;font-weight:700;letter-spacing:-.02em;display:flex;align-items:center;gap:10px;transition:opacity var(--transition-fast)}.header-left .logo:hover{opacity:.9}.logo-mark{width:44px;height:auto;flex-shrink:0}.header-nav{display:flex;align-items:center;gap:4px}.header-nav a{color:var(--color-text-secondary);text-decoration:none;font-size:13.5px;font-weight:500;padding:6px 14px;border-radius:var(--radius-sm);transition:all var(--transition-fast);position:relative}.header-nav a:hover{color:var(--color-text);background:#d46b3d14}.header-nav a.active{color:var(--color-primary-dark);background:#d46b3d1f}.header-right{margin-left:auto;display:flex;align-items:center;gap:16px}.header-feedback-alert{display:flex;align-items:center;gap:12px;padding:8px 14px;border-radius:999px;background:#bd232314;color:#8f1f1f;border:1px solid rgba(189,35,35,.16);font-size:12.5px;font-weight:600}.btn-feedback-link{background:#fff;color:#8f1f1f;text-decoration:none;padding:6px 12px}.user-email{font-size:13px;color:var(--color-text-muted);font-weight:400}.btn{padding:8px 18px;border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;font-size:13.5px;font-weight:500;font-family:var(--font-body);background:var(--color-surface);color:var(--color-text);transition:all var(--transition-fast);display:inline-flex;align-items:center;gap:6px}.btn:hover{background:var(--color-background);border-color:var(--color-text-muted)}.btn:active{transform:scale(.98)}.btn-primary{background:var(--color-primary);color:var(--color-text-inverse);border-color:var(--color-primary);font-weight:600}.btn-primary:hover{background:var(--color-primary-light);border-color:var(--color-primary-light)}.btn-danger{background:#dc3545;color:#fff;border-color:#dc3545}.btn-danger:hover{background:#b02a37;border-color:#b02a37}.btn-logout{background:#d46b3d14;color:var(--color-text-secondary);border:1px solid rgba(212,107,61,.16);font-size:13px;padding:6px 14px}.btn-logout:hover{background:#d46b3d24;color:var(--color-text);border-color:#d46b3d38}.btn-login{background:var(--color-primary);color:var(--color-text-inverse);border:none;padding:14px 32px;font-size:15px;font-weight:600;font-family:var(--font-heading);border-radius:var(--radius-sm);letter-spacing:-.01em;box-shadow:0 2px 8px #c93b174d;transition:all var(--transition-base)}.btn-login:hover{background:var(--color-primary-light);box-shadow:0 4px 16px #c93b1759;transform:translateY(-1px)}.btn-login:active{transform:translateY(0)}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:none;border-radius:var(--radius-sm);cursor:pointer;color:var(--color-text-muted);transition:all var(--transition-fast)}.btn-icon:hover{background:var(--color-primary-bg);color:var(--color-primary)}.main{flex:1;padding:28px 32px;position:relative}.route-loading-overlay{position:absolute;inset:0;z-index:9999;background:#fbf6f1bf;display:flex;align-items:center;justify-content:center}.route-loading-spinner{width:40px;height:40px;border:4px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:route-spin .7s linear infinite}@keyframes route-spin{to{transform:rotate(360deg)}}.main.main-pdf{padding:0;height:100vh;height:100dvh;min-height:100vh;min-height:100dvh;overflow:hidden}.page{max-width:1400px;margin:0 auto;animation:pageIn .3s ease both}@keyframes pageIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.page-header-actions{display:flex;gap:8px;align-items:center}.page-header h2{font-size:22px;font-weight:700;letter-spacing:-.02em;color:var(--color-text)}.page-header h2:before{content:"";display:inline-block;width:4px;height:20px;background:var(--color-primary);border-radius:2px;margin-right:12px;vertical-align:middle}.search-input{padding:8px 14px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:13.5px;font-family:var(--font-body);width:min(360px,100%);background:var(--color-surface);color:var(--color-text);transition:all var(--transition-fast);outline:none}.search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #c93b171a}.search-input::placeholder{color:var(--color-text-muted)}.login-page{display:flex;justify-content:center;align-items:center;min-height:100vh;background:var(--color-dark);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;top:-50%;right:-20%;width:800px;height:800px;background:radial-gradient(circle,rgba(201,59,23,.12) 0%,transparent 70%);pointer-events:none}.login-page:after{content:"";position:absolute;bottom:0;left:0;right:0;height:4px;background:var(--color-primary)}.login-card{background:var(--color-surface);padding:56px 48px;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);text-align:center;max-width:420px;width:100%;position:relative;animation:cardIn .4s ease both}@keyframes cardIn{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.login-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--color-primary);border-radius:var(--radius-lg) var(--radius-lg) 0 0}.login-logo-mark{width:180px;height:auto;display:block;margin:0 auto 16px}.login-card h1{margin-bottom:6px;color:var(--color-text);font-family:Bebas Neue,Outfit,sans-serif;font-size:48px;font-weight:400;letter-spacing:4px;text-transform:uppercase;letter-spacing:-.03em}.login-card p{margin-bottom:32px;color:var(--color-text-secondary);font-size:14.5px}.table-container{background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-card);overflow-x:auto;border:1px solid var(--color-border-light)}.data-table{width:max(100%,540px);border-collapse:collapse;font-size:13.5px;table-layout:fixed}.data-table th{background:var(--color-background);padding:11px 14px;text-align:left;font-weight:600;font-family:var(--font-heading);font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:var(--color-text-secondary);border-bottom:2px solid var(--color-border);cursor:pointer;white-space:nowrap;-webkit-user-select:none;user-select:none;transition:background var(--transition-fast)}.data-table th:hover{background:var(--color-background-alt);color:var(--color-text)}.data-table td{padding:10px 14px;border-bottom:1px solid var(--color-border-light);color:var(--color-text)}.data-table td.td-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:var(--color-primary-bg)}.data-table tbody tr:last-child td{border-bottom:none}.clickable-row{cursor:pointer}.clickable-row:active{background:var(--color-primary-bg-hover)!important}.order-star-btn{background:none;border:none;padding:0 8px 0 0;cursor:pointer;font-size:1.35rem;line-height:1;color:var(--color-text-muted);opacity:.6;transition:opacity .15s,color .15s,transform .1s;vertical-align:middle}.order-star-btn:hover{opacity:1;color:#e6a817;transform:scale(1.2)}.order-star-btn--active{opacity:1;color:#e6a817;text-shadow:0 0 6px rgba(230,168,23,.5)}.order-star-btn--active:hover{color:#c48b0f;transform:scale(1.15);text-shadow:0 0 8px rgba(230,168,23,.7)}.favorites-section{margin-bottom:12px;border-radius:var(--radius-md);border:1.5px solid rgba(230,168,23,.4);background:var(--color-surface);box-shadow:var(--shadow-card);overflow:clip}.favorites-section__header{display:flex;align-items:center;gap:7px;padding:10px 14px;background:linear-gradient(to right,rgba(230,168,23,.13),transparent 65%);border-bottom:1px solid rgba(230,168,23,.2);font-size:.72rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:#7a5500}.favorites-section__header span[aria-hidden]{font-size:.9rem;color:#e6a817}.favorites-section__scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.favorites-section__count{margin-left:2px;padding:1px 8px;border-radius:var(--radius-pill);background:#e6a8172e;color:#7a5500;font-size:.68rem;font-weight:700}.empty{text-align:center;color:var(--color-text-muted);padding:32px 24px!important;font-style:italic}.back-link{display:inline-flex;align-items:center;gap:6px;margin-bottom:16px;color:var(--color-text-secondary);text-decoration:none;font-size:13.5px;font-weight:500;transition:color var(--transition-fast)}.back-link:hover{color:var(--color-primary)}.detail-header{display:flex;align-items:center;gap:16px;margin-bottom:20px}.detail-header h2{font-size:22px;font-weight:700;letter-spacing:-.02em}.detail-header h2:before{content:"";display:inline-block;width:4px;height:20px;background:var(--color-primary);border-radius:2px;margin-right:12px;vertical-align:middle}.status-badge{background:var(--color-primary-bg);color:var(--color-primary);padding:4px 14px;border-radius:var(--radius-pill);font-size:12.5px;font-weight:600;font-family:var(--font-heading);letter-spacing:.02em}.detail-info{background:var(--color-surface);padding:20px 24px;border-radius:var(--radius-md);box-shadow:var(--shadow-card);border:1px solid var(--color-border-light);margin-bottom:28px;display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}.detail-info div{font-size:13.5px;color:var(--color-text)}.detail-info strong{color:var(--color-text-secondary);font-weight:500;font-size:12.5px;text-transform:uppercase;letter-spacing:.03em;display:block;margin-bottom:2px;font-family:var(--font-heading)}.page h3{font-size:15px;font-weight:600;color:var(--color-text-secondary);margin-bottom:12px;text-transform:uppercase;letter-spacing:.04em}.tabs{display:flex;gap:2px;margin-bottom:0}.tab{padding:10px 22px;border:none;background:var(--color-background-alt);color:var(--color-text-muted);cursor:pointer;font-size:13px;font-weight:500;font-family:var(--font-heading);border-radius:var(--radius-md) var(--radius-md) 0 0;letter-spacing:.02em;transition:all var(--transition-fast)}.tab:hover{color:var(--color-text-secondary);background:var(--color-background)}.tab.active{background:var(--color-surface);color:var(--color-primary);font-weight:600;box-shadow:inset 0 2px 0 var(--color-primary)}.tab-content{background:var(--color-surface);border-radius:0 var(--radius-md) var(--radius-md) var(--radius-md);box-shadow:var(--shadow-card);border:1px solid var(--color-border-light);overflow-x:auto}.pagination{display:flex;justify-content:center;gap:12px;padding:20px;align-items:center}.pagination span{font-size:13px;color:var(--color-text-secondary);font-weight:500}.pagination .btn:disabled{opacity:.4;cursor:not-allowed}.loading{text-align:center;padding:64px;color:var(--color-text-muted);font-size:14px}.loading:before{content:"";display:block;width:32px;height:32px;border:3px solid var(--color-border-light);border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite;margin:0 auto 16px}@keyframes spin{to{transform:rotate(360deg)}}.error-message{background:var(--color-error-bg);color:var(--color-error);padding:14px 18px;border-radius:var(--radius-md);margin-bottom:16px;font-size:13.5px;border-left:4px solid var(--color-error)}.access-denied-state{max-width:540px;margin:56px auto;padding:32px 28px;border-radius:var(--radius-lg);border:1px solid var(--color-border);background:linear-gradient(180deg,#fffffff5,#f8fafcf5);box-shadow:var(--shadow-card);text-align:center}.access-denied-icon{width:72px;height:72px;margin:0 auto 18px;border-radius:999px;display:grid;place-items:center;background:#bf532b1f;color:var(--color-error)}.access-denied-state h2{margin:0 0 10px;font-size:24px}.access-denied-state p{margin:0 0 22px;color:var(--color-text-muted);line-height:1.6}@media(max-width:768px){.search-input,.form-input,.contrib-filter-value,.vl-filter-search-input{font-size:16px!important}}@media(max-width:768px){.header{height:auto;padding:10px 12px;gap:10px;flex-wrap:wrap;align-items:center}.header-left{min-width:0}.header-left .logo{font-size:15px;gap:8px}.logo-mark{width:24px}.header-nav{order:3;width:100%}.header-nav a{padding:6px 10px;font-size:12.5px}.header-right{margin-left:auto;gap:8px;flex-wrap:wrap;justify-content:flex-end}.user-email{display:none}.btn-admin,.btn-logout{font-size:12px;padding:5px 10px}.main{padding:16px}.page-header{flex-direction:column;align-items:flex-start;gap:12px}.page-header-actions{width:100%;flex-direction:row;flex-wrap:wrap;align-items:center;gap:8px}.search-input{flex:1 1 140px;min-width:0}.page-header-actions select.form-input{flex:1 1 100%;width:100%}.page-header-actions .btn:not(.btn-primary){flex:1 1 auto}.pdf-breadcrumb{overflow-x:auto;white-space:nowrap;padding-bottom:4px}.pagination{flex-wrap:wrap;gap:8px;padding:14px 8px}.detail-info{grid-template-columns:1fr}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}::selection{background:#c93b1726;color:var(--color-text)}.btn-admin{background:#d46b3d14;color:var(--color-text-secondary);border:1px solid rgba(212,107,61,.16);font-size:12.5px;padding:5px 12px;gap:5px}.btn-admin:hover{background:#d46b3d24;color:var(--color-text);border-color:#d46b3d38}.btn-admin.active{background:var(--color-primary);color:var(--color-text-inverse);border-color:var(--color-primary)}.btn-admin.active:hover{background:var(--color-primary-light);border-color:var(--color-primary-light)}.suborder-actions{margin-top:24px;display:flex;gap:12px;align-items:center;flex-wrap:wrap}.upload-message{font-size:.85rem;padding:6px 12px;border-radius:6px;width:100%}.upload-message.success{color:#2e7d32;background:#4caf501a}.upload-message.error{color:#c62828;background:#c628281a}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.section-header h3{margin:0}.btn-sm{padding:6px 14px;font-size:13px;gap:6px}.form-label{display:block;font-size:13px;font-weight:600;margin-bottom:6px;color:var(--color-text-muted)}.form-input{width:100%;padding:8px 12px;border:1px solid var(--color-border-light);border-radius:6px;font-size:14px;box-sizing:border-box}.form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #2563eb1a}.file-selected{font-size:13px;color:var(--color-text-muted);margin-bottom:8px}.pdf-doc-list{display:flex;flex-direction:column;gap:8px;margin-bottom:32px}.pdf-doc-item{position:relative;background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius);padding:16px 20px;cursor:default;display:flex;gap:16px;align-items:flex-start}.pdf-doc-content{flex:1;min-width:0}.pdf-thumbnail{border:1px solid var(--color-border-light);border-radius:4px;background:#f5f5f5;flex-shrink:0;display:block;object-fit:contain}.pdf-thumbnail-shell{flex-shrink:0;border-radius:4px;overflow:hidden;background:linear-gradient(135deg,#78583e0d,#d46b3d0f)}.pdf-thumbnail-placeholder{width:100%;height:100%;border:1px solid var(--color-border-light);background:linear-gradient(90deg,#78583e14 25%,#78583e29,#78583e14 75%);background-size:220% 100%;animation:pdf-thumbnail-pulse 1.4s ease-in-out infinite}.pdf-doc-title{font-size:15px;font-weight:700;color:var(--color-text);margin:0 0 8px;text-transform:none;letter-spacing:-.01em}.pdf-doc-meta{font-size:13px;color:var(--color-text-muted);line-height:1.6}.pdf-doc-label{font-weight:600;color:var(--color-text);margin-right:6px}.pdf-doc-hover-actions{display:none;padding:8px 0 0;border-top:1px solid var(--color-border-light);margin-top:10px}.pdf-doc-item:hover .pdf-doc-hover-actions{display:flex;gap:16px}.pdf-doc-hover-actions a{font-size:13px;font-weight:500;color:var(--color-primary);cursor:pointer;text-decoration:none}.pdf-page-size{font-size:12px;color:var(--color-text-secondary)}.pdf-page-size-pending{opacity:.75;font-style:italic}@keyframes pdf-thumbnail-pulse{0%{background-position:100% 50%}to{background-position:0 50%}}.pdf-doc-hover-actions a:hover{text-decoration:underline}.pdf-doc-empty{color:var(--color-text-muted);font-size:14px;padding:16px 0}.marker-progress-section{margin-bottom:32px}.marker-progress-section h3{margin-bottom:10px}.marker-progress-legend{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:14px}.marker-progress-legend-item{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--color-text-muted)}.marker-progress-legend-dot{display:inline-block;width:10px;height:10px;border-radius:50%;flex-shrink:0}.marker-progress-list{display:flex;flex-direction:column;gap:10px}.marker-progress-row{display:flex;align-items:flex-start;gap:12px}.marker-progress-label{font-size:13px;font-weight:600;color:var(--color-text);min-width:160px;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-top:4px}.marker-progress-bar-wrap{flex:1;display:flex;flex-direction:column;gap:4px}.marker-progress-bar{height:16px;border-radius:4px;overflow:hidden;display:flex;background:var(--color-border-light)}.marker-progress-bar-segment{height:100%;transition:width .3s ease}.marker-progress-counts{display:flex;flex-wrap:wrap;gap:8px;font-size:12px}.marker-progress-total{color:var(--color-text-muted)}.versions-drawer{background:var(--color-surface);border-radius:12px;width:700px;max-width:95vw;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.versions-drawer-body{overflow-y:auto;padding:20px 24px;flex:1}.version-badge-latest{display:inline-block;padding:2px 10px;border-radius:12px;font-size:12px;font-weight:600;background:var(--color-primary);color:#fff}.version-link{color:var(--color-primary);cursor:pointer;text-decoration:underline;font-size:13px}.version-link.danger{color:var(--color-danger, #dc2626)}.contrib-th-sort{display:inline-flex;align-items:center;gap:4px;cursor:pointer;-webkit-user-select:none;user-select:none}.contrib-sort-indicator{font-size:10px;opacity:.55}.contrib-filter-icon-btn{display:inline-flex;align-items:center;justify-content:center;margin-left:4px;padding:2px 3px;border:none;background:transparent;color:var(--color-text-muted);cursor:pointer;border-radius:3px;vertical-align:middle;opacity:.6;transition:opacity .15s,color .15s}.contrib-filter-icon-btn:hover{opacity:1;color:var(--color-primary)}.contrib-filter-icon-btn.active{color:var(--color-primary);opacity:1}.contrib-filter-dialog{position:fixed;z-index:9999;width:430px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:6px;box-shadow:0 6px 24px #0000002e;font-size:13px;color:var(--color-text)}.contrib-filter-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px 8px;border-bottom:1px solid var(--color-border-light);font-weight:600;font-size:13px}.contrib-filter-close-btn{border:none;background:transparent;font-size:18px;line-height:1;cursor:pointer;color:var(--color-text-muted);padding:0 2px}.contrib-filter-close-btn:hover{color:var(--color-text)}.contrib-filter-body{padding:12px 14px 8px}.contrib-filter-desc{margin:0 0 2px;color:var(--color-text-secondary);font-size:12px}.contrib-filter-field-name{margin:0 0 10px;font-weight:700;color:var(--color-primary-dark);font-size:13px;border-bottom:1px solid var(--color-primary-light);padding-bottom:4px}.contrib-filter-row{display:flex;gap:8px;align-items:center;margin-bottom:8px}.contrib-filter-select,.contrib-filter-value{flex:1 1 0;min-width:0;padding:5px 8px;border:1px solid var(--color-border);border-radius:var(--radius-sm, 4px);background:var(--color-surface);color:var(--color-text);font-size:13px;font-family:var(--font-body)}.contrib-filter-value::placeholder{color:var(--color-text-muted);font-style:italic}.contrib-filter-logic{display:flex;gap:16px;margin:4px 0 10px;font-size:13px}.contrib-filter-logic label{display:flex;align-items:center;gap:5px;cursor:pointer}.contrib-filter-footer{display:flex;align-items:center;gap:8px;padding:8px 14px 12px;border-top:1px solid var(--color-border-light)}.contrib-filter-btn-primary{padding:6px 18px;border:none;border-radius:var(--radius-sm, 4px);background:#d46b3d24;color:var(--color-primary-dark);font-size:13px;font-family:var(--font-body);cursor:pointer;font-weight:600}.contrib-filter-btn-primary:hover{background:#d46b3d3d}.contrib-filter-btn-outline{padding:6px 16px;border:1px solid var(--color-border);border-radius:var(--radius-sm, 4px);background:transparent;color:var(--color-text-secondary);font-size:13px;font-family:var(--font-body);cursor:pointer}.contrib-filter-btn-outline:hover{background:var(--color-background-alt)}.vl-filter-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;padding:0;margin-left:2px;border:none;background:transparent;cursor:pointer;color:var(--color-text-muted);opacity:.5;border-radius:3px;flex-shrink:0}.vl-filter-icon-btn:hover{opacity:1;color:var(--color-primary)}.vl-filter-icon-btn.active{color:var(--color-primary);opacity:1;background:#d46b3d1f}.vl-filter-dialog{position:fixed;z-index:9999;width:300px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:6px;box-shadow:0 4px 20px #0000002e;display:flex;flex-direction:column;font-size:13px}.vl-filter-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px 8px;border-bottom:1px solid var(--color-border);font-size:13px;color:var(--color-text-secondary)}.vl-filter-close-btn{border:none;background:transparent;font-size:18px;line-height:1;cursor:pointer;color:var(--color-text-muted);padding:0 2px}.vl-filter-close-btn:hover{color:var(--color-text)}.vl-filter-search{padding:8px 12px;border-bottom:1px solid var(--color-border)}.vl-filter-search-input{width:100%;box-sizing:border-box;padding:5px 8px;border:1px solid var(--color-border);border-radius:4px;background:var(--color-background);color:var(--color-text);font-size:13px}.vl-filter-search-input:focus{outline:none;border-color:var(--color-primary)}.vl-filter-list{max-height:240px;overflow-y:auto;padding:4px 0}.vl-filter-item{display:flex;align-items:center;gap:8px;padding:4px 14px;cursor:pointer;-webkit-user-select:none;user-select:none}.vl-filter-item:hover{background:var(--color-background-alt)}.vl-filter-item-all{border-bottom:1px solid var(--color-border);margin-bottom:2px;padding-bottom:6px;font-style:italic}.vl-filter-item-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vl-filter-empty{padding:10px 14px;color:var(--color-text-muted);font-style:italic}.vl-filter-footer{display:flex;align-items:center;gap:8px;padding:8px 12px;border-top:1px solid var(--color-border)}.vl-filter-btn-primary{padding:6px 18px;border:none;border-radius:4px;background:#d46b3d26;color:var(--color-primary);font-size:13px;font-weight:600;cursor:pointer}.vl-filter-btn-primary:hover{background:#d46b3d3d}.vl-filter-btn-outline{padding:6px 16px;border:1px solid var(--color-border);border-radius:4px;background:transparent;color:var(--color-text);font-size:13px;cursor:pointer}.vl-filter-btn-outline:hover{background:var(--color-background-alt)}.modal-description{margin:0 0 16px;color:var(--color-text-muted);font-size:14px;line-height:1.5}.btn-pdf{padding:12px 24px;font-size:14.5px;font-weight:600;font-family:var(--font-heading);letter-spacing:-.01em;gap:8px}.btn-pdf svg{flex-shrink:0}.montage-filemanager{margin-top:28px}.montage-filemanager h3{margin-bottom:12px}.montage-entries{border:1px solid var(--color-border);border-radius:8px;overflow:hidden}.montage-folder-item,.montage-file-item{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;border-bottom:1px solid var(--color-border);transition:background .15s}.montage-folder-item:last-child,.montage-file-item:last-child{border-bottom:none}.montage-folder-item:hover{background:var(--color-surface-hover, rgba(255,255,255,.05))}.montage-file-item:hover{background:var(--color-primary-muted, rgba(99,102,241,.08))}.montage-folder-icon,.montage-file-icon{position:relative;width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.montage-folder-icon:before{content:"";position:absolute;left:1px;right:1px;bottom:2px;height:12px;border-radius:3px;background:linear-gradient(180deg,#efc46d,#d89a2f);box-shadow:inset 0 0 0 1px #78583e1f}.montage-folder-icon:after{content:"";position:absolute;left:3px;top:2px;width:9px;height:5px;border-radius:3px 3px 0 0;background:#e7b554;box-shadow:inset 0 0 0 1px #78583e14}.montage-file-icon:before{content:"";position:absolute;inset:1px 3px;border-radius:3px;background:linear-gradient(180deg,#fff3ee,#ffd8c8);box-shadow:inset 0 0 0 1px #bf532b33,0 1px 2px #78583e1a}.montage-file-icon:after{content:"PDF";position:absolute;left:4px;right:4px;bottom:4px;height:7px;border-radius:2px;background:linear-gradient(180deg,#e87c4f,#d95e2e);color:#fff;font-size:5px;font-weight:800;letter-spacing:.06em;line-height:7px;text-align:center;font-family:var(--font-heading);box-shadow:0 1px 1px #78583e1f}.montage-item-name{flex:1;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.montage-item-meta{font-size:12px;color:var(--color-text-muted);white-space:nowrap;flex-shrink:0}.montage-breadcrumb{display:flex;align-items:center;flex-wrap:wrap;gap:2px;font-size:13px;margin-bottom:10px;color:var(--color-text-muted)}.montage-breadcrumb-link{color:var(--color-primary);cursor:pointer;text-decoration:underline}.montage-breadcrumb-sep{color:var(--color-text-muted)}.montage-breadcrumb-current{color:var(--color-text);font-weight:500}.montage-viewer-overlay{position:fixed;inset:0;z-index:5000;padding:max(12px,env(safe-area-inset-top)) max(12px,env(safe-area-inset-right)) max(12px,env(safe-area-inset-bottom)) max(12px,env(safe-area-inset-left));background:linear-gradient(180deg,#18120eeb,#18120ef5);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}body.montage-viewer-open{overflow:hidden}.montage-viewer-shell{position:relative;width:100%;height:calc(100dvh - 24px);display:grid;grid-template-columns:minmax(300px,360px) minmax(0,1fr);gap:0}.montage-viewer-close{position:absolute;top:14px;right:14px;z-index:2;width:44px;height:44px;border:1px solid rgba(120,88,62,.18);border-radius:999px;background:#fffaf6f0;color:var(--color-text);font-size:28px;line-height:1;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 10px 24px #1a120d29;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.montage-viewer-close:hover{background:#fff;color:var(--color-primary-dark)}.montage-viewer-sidebar{min-width:0;background:linear-gradient(180deg,#fffaf6,#f4ece4);border:1px solid rgba(120,88,62,.14);border-right:none;border-radius:22px 0 0 22px;box-shadow:0 24px 48px #1a120d33;display:flex;flex-direction:column;overflow:hidden}.montage-viewer-file-list{overflow-y:auto;flex:1;padding:68px 0 12px}.montage-viewer-file-item{display:flex;align-items:center;width:100%;border:none;background:transparent;text-align:left;gap:10px;padding:14px 18px;cursor:pointer;font-size:14px;transition:background .15s,color .15s}.montage-viewer-file-item:hover{background:#d46b3d14}.montage-viewer-file-item.active{background:#d46b3d24;color:var(--color-primary-dark);font-weight:700}.montage-viewer-file-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.montage-viewer-main{display:flex;flex-direction:column;min-width:0;overflow:hidden;background:#fffdfb;border:1px solid rgba(120,88,62,.14);border-radius:0 22px 22px 0;box-shadow:0 24px 48px #1a120d33}.montage-viewer-topbar{display:flex;align-items:center;justify-content:center;min-height:82px;padding:18px 24px;border-bottom:1px solid rgba(120,88,62,.12);background:linear-gradient(180deg,#fff7f0,#f8efe7);flex-shrink:0}.montage-viewer-filename{flex:1;text-align:center;font-size:18px;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.montage-viewer-stage{flex:1;min-height:0;background:radial-gradient(circle at top,rgba(212,107,61,.08),transparent 30%),#f4eee8;overflow:hidden}.montage-viewer-iframe{width:100%;height:100%;border:none;background:#f4eee8}@media(max-width:1180px){.montage-viewer-shell{grid-template-columns:1fr;grid-template-rows:220px minmax(0,1fr)}.montage-viewer-overlay{padding:10px}.montage-viewer-sidebar{border-right:1px solid rgba(120,88,62,.14);border-bottom:none;border-radius:18px 18px 0 0}.montage-viewer-main{border-radius:0 0 18px 18px}.montage-viewer-topbar{min-height:74px;justify-content:center;padding:14px 16px}.montage-viewer-filename{font-size:16px}}@media(max-width:820px){.montage-viewer-shell{height:calc(100dvh - 20px);grid-template-rows:190px minmax(0,1fr)}.montage-viewer-sidebar-header{padding:14px 16px}.montage-viewer-file-item{padding:12px 14px;font-size:13px}.montage-viewer-close{top:10px;right:10px;width:40px;height:40px;font-size:24px}.montage-viewer-topbar{display:flex;justify-content:center}.montage-viewer-filename{font-size:14px}}.pdf-breadcrumb{display:flex;align-items:center;gap:6px;margin-bottom:16px;font-size:13px;font-weight:500}.breadcrumb-link{color:var(--color-text-muted);text-decoration:none;transition:color var(--transition-fast)}.breadcrumb-link:hover{color:var(--color-primary)}.breadcrumb-sep{color:var(--color-border);font-size:11px}.breadcrumb-current{color:var(--color-text);font-weight:600}.pdf-page{animation:pageIn .3s ease both;height:100%}.pdf-page .main{padding:0}.pdf-viewer-shell{display:flex;flex-direction:column;height:calc(100vh - 140px);background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border-light);box-shadow:var(--shadow-card);overflow:hidden}.pdf-toolbar{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:var(--color-background);border-bottom:1px solid var(--color-border-light);gap:16px;flex-shrink:0}.pdf-toolbar-left{display:flex;align-items:center;gap:12px}.pdf-toolbar-page{display:flex;align-items:center;gap:8px}.pdf-page-status{font-size:12.5px;color:var(--color-text-secondary);font-variant-numeric:tabular-nums;min-width:92px;text-align:center}.pdf-toolbar-label{font-family:var(--font-heading);font-weight:600;font-size:13.5px;color:var(--color-text)}.pdf-toolbar-divider{width:1px;height:16px;background:var(--color-border)}.pdf-toolbar-zoom{font-size:12.5px;color:var(--color-text-secondary);font-variant-numeric:tabular-nums}.pdf-toolbar-right{display:flex;align-items:center;gap:12px}.pdf-toolbar-badge{font-size:12px;padding:3px 10px;border-radius:var(--radius-pill);font-weight:500}.admin-badge{background:#c93b171a;color:var(--color-primary);border:1px solid rgba(201,59,23,.2)}.pdf-toolbar-hint{font-size:12px;color:var(--color-text-muted)}.pdf-container{position:relative;flex:1;overflow:hidden;-webkit-user-select:none;user-select:none;background-color:var(--color-background);background-image:radial-gradient(circle,var(--color-border-light) 1px,transparent 1px);background-size:20px 20px}.pdf-loading-inner{padding:64px;text-align:center;color:var(--color-text-muted)}.pdf-no-file{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:var(--color-text-muted);max-width:400px}.pdf-no-file-icon{margin-bottom:16px;color:var(--color-border)}.pdf-no-file h3{font-size:18px;color:var(--color-text-secondary);margin-bottom:8px}.pdf-no-file p{font-size:13.5px;line-height:1.6;margin-bottom:4px}.pdf-no-file code{background:var(--color-background-alt);padding:2px 6px;border-radius:3px;font-size:12.5px}.location-marker{position:absolute;transform:translate(-50%,-50%);z-index:10;pointer-events:auto;transition:opacity .12s ease}.marker-label{position:absolute;left:50%;transform:translate(-50%);white-space:nowrap;font-family:var(--font-heading);font-weight:600;border-width:1px;border-style:solid;border-radius:var(--radius-sm);box-shadow:0 2px 6px #0000001f;line-height:1;pointer-events:none}.marker-pin{background:var(--color-surface);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000002e;border:2px solid;transition:transform var(--transition-fast)}.location-marker:hover .marker-pin{transform:scale(1.15)}.marker-context-menu{position:fixed;z-index:1000;background:var(--color-surface);border-radius:var(--radius-md);box-shadow:0 8px 30px #0000002e,0 2px 8px #00000014;border:1px solid var(--color-border-light);min-width:240px;overflow:hidden;animation:menuIn .15s ease both}@keyframes menuIn{0%{opacity:0}to{opacity:1}}.marker-menu-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--color-border-light);font-family:var(--font-heading);font-weight:600;font-size:14px;color:var(--color-text)}.marker-menu-close{background:none;border:none;font-size:18px;cursor:pointer;color:var(--color-text-muted);padding:0 4px;line-height:1}.marker-menu-close:hover{color:var(--color-text)}.marker-menu-status{display:flex;align-items:center;gap:8px;padding:8px 14px;font-size:12.5px;color:var(--color-text-secondary);background:var(--color-background)}.marker-menu-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.marker-menu-divider{height:1px;background:var(--color-border-light)}.marker-menu-item{display:block;width:100%;padding:9px 14px;border:none;background:none;text-align:left;font-size:13.5px;font-family:var(--font-body);color:var(--color-text);cursor:pointer;transition:background var(--transition-fast)}.marker-menu-item:hover{background:var(--color-primary-bg)}.marker-menu-item.success{color:#2d6a4f;font-weight:500}.marker-menu-item.success:hover{background:#2d6a4f14}.marker-menu-item.danger{color:var(--color-error)}.marker-menu-item.danger:hover{background:var(--color-error-bg)}.modal-overlay{position:fixed;inset:0;background:#00000073;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-card{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:480px;animation:cardIn .25s ease both;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--color-border-light)}.modal-header h3{font-size:16px;font-weight:700;color:var(--color-text);text-transform:none;letter-spacing:-.01em}.modal-close{background:none;border:none;font-size:22px;cursor:pointer;color:var(--color-text-muted);padding:0 4px;line-height:1}.modal-close:hover{color:var(--color-text)}.modal-body{padding:24px}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 24px;border-top:1px solid var(--color-border-light);background:var(--color-background)}.oplever-checklist-modal{max-width:480px}.oplever-intro{font-size:.85rem;color:var(--color-text-secondary);margin-bottom:12px}.oplever-questions{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.oplever-question{padding:8px 10px;border-radius:8px;border:1px solid var(--color-border-light);background:var(--color-background);transition:border-color .15s}.oplever-question.approved{border-color:#4caf50;background:#4caf500f}.oplever-question-row{display:flex;align-items:center}.oplever-question-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.85rem;font-weight:500;color:var(--color-text)}.oplever-question-label input[type=checkbox]{width:16px;height:16px;accent-color:#4caf50;cursor:pointer}.oplever-reden{margin-top:6px;font-size:.8rem}.oplever-photo-count{font-weight:400;color:var(--color-text-muted)}.oplever-photo-hint{font-size:.78rem;color:var(--color-text-muted);margin:0 0 8px}.oplever-photo-upload-btn{display:inline-block;padding:6px 14px;font-size:.82rem;font-weight:600;color:var(--color-primary);border:1px dashed var(--color-primary);border-radius:6px;cursor:pointer;transition:background .15s;margin-bottom:8px}.oplever-photo-upload-btn:hover{background:rgba(var(--color-primary-rgb, 59, 130, 246),.08)}.oplever-photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:6px;margin-top:4px}.oplever-photo-thumb{position:relative;aspect-ratio:1;border-radius:6px;overflow:hidden;border:1px solid var(--color-border-light)}.oplever-photo-thumb img{width:100%;height:100%;object-fit:cover}.oplever-photo-remove{position:absolute;top:2px;right:2px;width:20px;height:20px;border-radius:50%;background:#0009;color:#fff;border:none;font-size:14px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}.oplever-photo-remove:hover{background:#dc2626d9}.oplevering-photo-viewer-overlay{z-index:2100}.oplevering-photo-viewer{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:calc(100vw - 48px);height:calc(100vh - 48px);max-width:1400px;animation:cardIn .25s ease both;overflow:hidden;display:flex;flex-direction:column}.oplevering-photo-viewer .modal-header{display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.oplevering-photo-header-actions{display:flex;align-items:center;gap:8px}.oplevering-photo-zoom-btn{width:32px;height:32px;border-radius:50%;border:1px solid var(--color-border-light);background:var(--color-background);font-size:18px;cursor:pointer;color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center;transition:background .15s}.oplevering-photo-zoom-btn:hover{background:var(--color-surface);color:var(--color-text)}.oplevering-photo-stage{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0;min-height:0;position:relative;overflow:hidden}.oplevering-photo-transform-area{flex:1;width:100%;min-height:0;overflow:hidden;cursor:grab;background:var(--color-background)}.oplevering-photo-transform-area:active{cursor:grabbing}.oplevering-photo-image{max-width:100%;max-height:100%;object-fit:contain;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.oplevering-photo-bottom-bar{flex-shrink:0;display:flex;flex-direction:column;align-items:center;padding:10px 16px 14px;background:var(--color-surface);border-top:1px solid var(--color-border-light)}.oplevering-photo-nav{display:flex;align-items:center;gap:16px}.oplevering-photo-nav-btn{width:40px;height:40px;border-radius:50%;border:1px solid var(--color-border-light);background:var(--color-background);font-size:24px;line-height:1;cursor:pointer;color:var(--color-text);display:flex;align-items:center;justify-content:center;transition:background .15s}.oplevering-photo-nav-btn:hover:not(:disabled){background:var(--color-surface)}.oplevering-photo-nav-btn:disabled{opacity:.3;cursor:default}.oplevering-photo-counter{font-size:.85rem;font-weight:600;color:var(--color-text-secondary);min-width:48px;text-align:center}.oplevering-photo-filename{font-size:.75rem;color:var(--color-text-muted);margin-top:4px;text-align:center;word-break:break-all}.oplevering-photo-hint{font-size:.7rem;color:var(--color-text-muted);margin-top:2px;opacity:.7}.oplevering-photo-loading,.oplevering-photo-error,.oplevering-photo-empty{font-size:.9rem;color:var(--color-text-muted);text-align:center;padding:40px 0}.oplevering-photo-error{color:#dc2626}.form-group{margin-bottom:16px}.form-label{display:block;font-size:12.5px;font-weight:600;font-family:var(--font-heading);text-transform:uppercase;letter-spacing:.03em;color:var(--color-text-secondary);margin-bottom:6px}.form-input{width:100%;padding:9px 12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:13.5px;font-family:var(--font-body);color:var(--color-text);background:var(--color-surface);outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #c93b171a}textarea.form-input{resize:vertical;min-height:60px}select.form-input{cursor:pointer}.image-preview{display:block;margin-top:10px;max-width:140px;border-radius:var(--radius-sm);border:1px solid var(--color-border-light)}.opleveren-page{max-width:720px}.opleveren-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:16px;flex-wrap:wrap}.opleveren-header h2{font-size:22px;font-weight:700;letter-spacing:-.02em}.opleveren-header h2:before{content:"";display:inline-block;width:4px;height:20px;background:var(--color-primary);border-radius:2px;margin-right:12px;vertical-align:middle}.opleveren-marker-info{display:flex;align-items:center;gap:10px}.opleveren-marker-name{font-family:var(--font-heading);font-weight:600;font-size:14px;color:var(--color-text-secondary)}.opleveren-status{font-size:12px;padding:3px 12px;border-radius:var(--radius-pill);font-weight:600;font-family:var(--font-heading);text-transform:uppercase;letter-spacing:.03em}.status-nieuw{background:#f0f0f0;color:#8e8e93}.status-geopperd{background:#fef3e2;color:#b45309}.status-gemonteerd{background:#e8f4fd;color:#2563eb}.status-opgeleverd{background:#e6f4ea;color:#2d6a4f}.opleveren-card{background:var(--color-surface);padding:24px;border-radius:var(--radius-md);box-shadow:var(--shadow-card);border:1px solid var(--color-border-light);margin-bottom:24px}.checklist-item{padding:14px 0;border-bottom:1px solid var(--color-border-light)}.checklist-item:last-of-type{border-bottom:none}.checklist-row{display:flex;align-items:center;gap:14px}.checklist-label{font-size:14px;color:var(--color-text);font-weight:500}.checklist-reden{margin-top:10px;margin-left:56px}.checklist-toggle{background:none;border:none;cursor:pointer;padding:0;flex-shrink:0}.toggle-track{display:block;width:42px;height:24px;border-radius:12px;background:var(--color-border);position:relative;transition:background var(--transition-fast)}.akkoord .toggle-track{background:#2d6a4f}.toggle-thumb{position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0003;transition:transform var(--transition-fast)}.akkoord .toggle-thumb{transform:translate(18px)}.opleveren-actions{display:flex;gap:10px;flex-wrap:wrap}.btn-success{background:#2d6a4f;color:var(--color-text-inverse);border-color:#2d6a4f;font-weight:600}.btn-success:hover{background:#236b4a;border-color:#236b4a}@media(max-width:768px){.pdf-viewer-shell{height:calc(100vh - 120px);border-radius:0;border:none}.pdf-toolbar{flex-direction:column;align-items:flex-start;gap:6px;padding:8px 12px}.pdf-toolbar-left,.pdf-toolbar-right{width:100%;flex-wrap:wrap}.pdf-toolbar-page{width:100%;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:6px}.pdf-toolbar-page .btn{min-width:76px;padding:6px 10px;font-size:12px;justify-content:center}.pdf-page-status{width:auto;text-align:center;min-width:0;white-space:nowrap}.pdf-toolbar-right{flex-wrap:wrap}.opleveren-actions{flex-direction:column}.opleveren-actions .btn{width:100%;justify-content:center}.checklist-reden{margin-left:0}}.pdf-viewer-workspace{height:100vh;height:100dvh;min-height:100vh;min-height:100dvh;padding:0;overflow:hidden;background:linear-gradient(135deg,#f7f3ef,#f0ece8);border-radius:0;border:none;box-shadow:none}.pdf-workspace{display:flex;height:100%;min-height:0}.pdf-icon-rail{width:72px;background:linear-gradient(180deg,#fff9f4,#f4e8dc);color:var(--color-text);display:flex;flex-direction:column;justify-content:space-between;align-items:center;padding:0;box-shadow:inset -1px 0 #78583e14;flex-shrink:0}.pdf-icon-stack,.pdf-icon-rail-footer{display:flex;flex-direction:column;align-items:center;gap:8px;width:100%}.pdf-icon-stack{padding-top:0}.pdf-icon-rail-footer{padding-bottom:0}.pdf-rail-button{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast);border-radius:12px;position:relative}.pdf-rail-button:hover,.pdf-rail-button.selected{background:#d46b3d1f;color:var(--color-primary-dark)}.pdf-rail-button-divider{margin-top:10px;border-top:2px solid rgba(120,88,62,.12);border-radius:0 0 12px 12px;padding-top:10px}.pdf-rail-badge{position:absolute;top:4px;right:2px;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:#c53030;color:#fff;font-size:10px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 4px 10px #c5303040}.pdf-side-panel{width:min(360px,32vw);min-width:300px;background:#fffdfb;border-right:1px solid var(--color-border-light);box-shadow:12px 0 24px #78583e14;display:flex;flex-direction:column;flex-shrink:0;min-height:0}.pdf-side-panel-header{display:flex;align-items:center;gap:12px;padding:18px 20px 14px;border-bottom:1px solid var(--color-border-light)}.pdf-side-panel:has(.add-panel) .pdf-side-panel-header{padding:12px 16px 10px}.pdf-side-panel-header h3,.pdf-template-card h3,.pdf-placement-card h3,.pdf-side-panel-subtitle{text-transform:none;letter-spacing:0;margin-bottom:0;color:var(--color-text)}.pdf-panel-close{width:36px;height:36px;border-radius:10px;border:none;background:var(--color-background-alt);color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer}.pdf-side-panel-content{padding:18px 20px 20px;overflow-y:auto;min-height:0}.pdf-side-panel-content.add-panel{padding:10px 12px 12px;overflow-y:hidden;gap:6px}.pdf-side-panel-content.info{display:flex;flex-direction:column;gap:10px}.pdf-side-panel-content.info label,.pdf-property-list label{display:flex;justify-content:space-between;gap:12px;padding:8px 10px;background:var(--color-background);border-radius:10px;font-size:12px;color:var(--color-text-secondary)}.pdf-side-panel-content.info label span,.pdf-property-list label span{color:var(--color-text);font-weight:600;text-align:right}.pdf-side-panel-subtitle{margin-top:26px}.pdf-panel-text{color:var(--color-text-secondary);line-height:1.6}.pdf-panel-text-spaced{margin-top:18px}.pdf-submit-button{border:none;background:#d46b3d24;color:var(--color-primary-dark);border-radius:12px;padding:12px 14px;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;font-weight:600;border:1px solid rgba(212,107,61,.18)}.pdf-submit-button:disabled{opacity:.55;cursor:not-allowed}.pdf-submit-button.green{background:#2d6a4f;color:#fff;border-color:#2d6a4f}.pdf-submit-button.red{background:#c53030;color:#fff;border-color:#c53030}.pdf-panel-message,.pdf-empty-state{margin-top:12px;background:var(--color-background);border-radius:12px;padding:12px 14px;color:var(--color-text-secondary);line-height:1.5}.pdf-nav-item,.pdf-bookmark-item,.pdf-template-card{width:100%;border:none;background:transparent;text-align:left;cursor:pointer}.pdf-nav-item{display:grid;grid-template-columns:36px 88px 1fr;gap:12px;align-items:center;padding:10px;border-radius:14px;margin-bottom:10px;transition:background var(--transition-fast),transform var(--transition-fast)}.pdf-nav-item:hover,.pdf-nav-item.active{background:#d46b3d24;transform:translate(2px)}.pdf-nav-number{width:30px;height:30px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:var(--color-primary);color:#fff;font-size:12px;font-weight:700;box-shadow:0 8px 16px #d46b3d38}.pdf-nav-item.active .pdf-nav-number{background:var(--color-primary-dark)}.pdf-nav-thumb{width:88px;height:88px;border-radius:10px;overflow:hidden;background:#ece6de;border:1px solid var(--color-border-light)}.pdf-nav-thumb img,.pdf-nav-thumb-placeholder{width:100%;height:100%;object-fit:cover}.pdf-nav-thumb-placeholder{display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);font-size:12px}.pdf-nav-title{color:var(--color-text);font-weight:600;line-height:1.35}.pdf-nav-item.active .pdf-nav-title{color:var(--color-primary-dark)}.pdf-bookmark-item{display:block;padding:10px 12px;border-radius:10px;margin-bottom:4px;color:var(--color-text-secondary)}.pdf-bookmark-item.available:hover{background:#c93b1714;color:var(--color-primary)}.pdf-template-group+.pdf-template-group{margin-top:8px}.pdf-template-heading{margin-bottom:4px;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em;font-size:11px}.pdf-side-panel-content.add-panel .pdf-template-group{display:grid;grid-template-columns:1fr;gap:6px}.pdf-side-panel-content.add-panel .pdf-template-heading{grid-column:1 / -1}.pdf-template-card{position:relative;padding:8px 10px 7px;background:#faf7f3;border-radius:12px;border:1px solid transparent;margin-bottom:0;overflow:visible}.pdf-template-card.selected{border-color:#d46b3d52;background:#d46b3d1a}.pdf-template-version{position:absolute;top:8px;right:10px;color:var(--color-text-muted);font-size:10px;margin-bottom:0;line-height:1}.pdf-template-card h3{display:inline-block;margin:0;padding-right:64px;font-size:16px;line-height:1.15;position:relative;z-index:1}.pdf-template-card p{position:absolute;top:calc(100% + 6px);left:10px;right:10px;margin:0;padding:8px 10px;border-radius:10px;background:#251f1cf5;color:#fff;font-size:13px;line-height:1.35;opacity:0;transform:translateY(-4px);pointer-events:none;transition:opacity .15s ease,transform .15s ease;z-index:6}.pdf-template-card h3:hover+p,.pdf-template-card h3:focus+p{opacity:1;transform:translateY(0)}.pdf-placement-card{margin-top:6px;background:#fffaf5;color:var(--color-text);border:1px solid var(--color-border-light);border-radius:14px;padding:10px;display:flex;flex-direction:column;gap:8px}.pdf-placement-card h3,.pdf-placement-card h4,.pdf-placement-card p,.pdf-placement-card li{color:var(--color-text)}.pdf-placement-header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.pdf-placement-header p{font-size:13px;color:var(--color-text-secondary)}.pdf-placement-help{position:relative;width:24px;height:24px;flex:0 0 auto;border-radius:999px;background:#d46b3d1f;color:var(--color-primary-dark);display:inline-flex;align-items:center;justify-content:center;font-weight:700;cursor:help}.pdf-placement-tooltip{position:absolute;top:calc(100% + 8px);right:0;width:240px;padding:10px 12px;border-radius:12px;background:#251f1cf5;color:#fff;box-shadow:0 14px 28px #00000038;font-size:12px;line-height:1.45;opacity:0;pointer-events:none;transform:translateY(-4px);transition:opacity .15s ease,transform .15s ease;z-index:5}.pdf-placement-help:hover .pdf-placement-tooltip,.pdf-placement-help:focus .pdf-placement-tooltip,.pdf-placement-help:focus-within .pdf-placement-tooltip{opacity:1;transform:translateY(0)}.pdf-property-list{display:flex;flex-direction:column;gap:6px}.pdf-badge{display:inline-flex;align-self:flex-start;background:var(--color-primary-bg);color:var(--color-primary);border-radius:999px;padding:6px 12px;font-weight:700}.pdf-stage-shell{flex:1;min-width:0;display:flex;flex-direction:column;position:relative}.pdf-top-actions{position:absolute;top:10px;right:14px;z-index:30}.pdf-top-menu-trigger{width:42px;height:42px;border:1px solid rgba(212,107,61,.2);border-radius:999px;background:var(--color-primary);color:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 12px 28px #d46b3d42}.pdf-overflow-menu{position:absolute;top:48px;right:0;width:280px;background:#fffcf9fc;border:1px solid var(--color-border-light);border-radius:18px;box-shadow:0 20px 40px #78583e24;overflow:hidden}.pdf-overflow-meta{padding:14px 16px 12px;border-bottom:1px solid var(--color-border-light);display:flex;flex-direction:column;gap:10px}.pdf-overflow-email{font-size:13px;color:var(--color-text-secondary);word-break:break-word}.pdf-overflow-admin{align-self:flex-start;border:1px solid rgba(212,107,61,.18);background:#d46b3d14;color:var(--color-primary-dark);border-radius:999px;padding:6px 12px;cursor:pointer;font-weight:600}.pdf-overflow-admin.active{background:#d46b3d29}.pdf-overflow-item{width:100%;border:none;background:transparent;text-align:left;padding:12px 16px;color:var(--color-text);cursor:pointer;display:flex;align-items:center;gap:10px}.pdf-overflow-item:hover{background:#d46b3d14}.pdf-floating-panel{position:fixed;top:84px;right:max(16px,env(safe-area-inset-right));z-index:20;width:min(460px,calc(100vw - 32px));max-width:calc(100vw - 32px)}.pdf-floating-panel-content{background:#fffbf7f5;color:var(--color-text);padding:12px 14px;border-radius:16px;box-shadow:0 18px 40px #00000038}.pdf-floating-panel-content h4{color:var(--color-text);margin-bottom:1px;margin-top:3px;font-size:.85rem}.pdf-container{flex:1;min-height:0;overflow:hidden;position:relative;background:radial-gradient(circle at top left,rgba(201,59,23,.12),transparent 28%),linear-gradient(180deg,#f5f2ee,#ebe5de)}.pdf-container.placement-active:after{content:"";position:absolute;inset:0;border:2px dashed rgba(201,59,23,.25);pointer-events:none}.pdf-transform-wrapper{width:100%;height:100%;overflow:hidden}.pdf-transform-content{min-width:100%;min-height:100%;width:max-content;height:max-content;display:flex;align-items:center;justify-content:center}.pdf-stage-shell{position:relative}.pdf-stage-page,.pdf-stage-annotations,.pdf-stage-imported-annotations,.pdf-stage-annotation-interaction,.pdf-stage-markers,.pdf-dim-layer{position:absolute}.pdf-stage-page{z-index:1;box-shadow:0 20px 40px #1c1c1e2e;overflow:hidden;background:transparent}.pdf-render-layer{position:absolute;top:0;left:0;transition:opacity 90ms linear}.pdf-page-snapshot{position:absolute;inset:0}.pdf-page-snapshot{z-index:2;background:transparent}.pdf-page-snapshot img{width:100%;height:100%;object-fit:fill}.pdf-stage-markers{z-index:6;pointer-events:none}.pdf-stage-annotations{z-index:2;pointer-events:none}.pdf-stage-imported-annotations{z-index:5;pointer-events:none}.pdf-stage-imported-annotations svg{pointer-events:none}.pdf-stage-imported-annotations .imported-annotation{pointer-events:none}.pdf-stage-annotation-interaction{z-index:3;pointer-events:auto}.pdf-annotation-layer{overflow:visible;pointer-events:none}.pdf-imported-annotation-layer{overflow:visible}.imported-annotation{transition:opacity .15s}.imported-annotation-tooltip{background:#1e1e1ee6;color:#fff;border-radius:6px;padding:4px 8px;font-size:11px;text-align:center;white-space:nowrap;line-height:1.4;box-shadow:0 2px 8px #0000004d}.imported-ann-code{font-weight:600;color:#ffa94d}.imported-ann-value{font-weight:500}.pdf-annotation-hit-layer{overflow:visible;pointer-events:auto}.pdf-dim-layer{z-index:2;background:#000;pointer-events:none}.pdf-placement-hint{position:absolute;left:24px;top:24px;z-index:4;background:#fffbf7f5;color:var(--color-text);border:1px solid var(--color-border-light);border-radius:12px;padding:10px 14px}.pdf-placement-capture{position:absolute;z-index:4;background:transparent;touch-action:none}.pdf-mobile-placement-dock{position:absolute;left:16px;right:16px;bottom:88px;z-index:5;display:none;background:#fffcf9f5;border:1px solid var(--color-border-light);border-radius:16px;box-shadow:0 16px 32px #78583e29;padding:12px;gap:10px}.pdf-mobile-placement-text{color:var(--color-text);font-weight:600;line-height:1.35}.pdf-mobile-placement-actions{display:flex;gap:8px;flex-wrap:wrap}.pdf-mobile-placement-actions .pdf-submit-button{flex:1 1 0;min-width:0;padding:10px 12px}.pdf-bottom-dock-panel{position:absolute;left:16px;right:16px;bottom:84px;height:min(40%,360px);min-height:260px;z-index:6;background:linear-gradient(40deg,#fffffffa,#ebe5defa);border:1px solid rgba(120,88,62,.14);border-radius:20px;box-shadow:0 24px 48px #78583e2e;display:flex;flex-direction:column;overflow:hidden;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.pdf-bottom-dock-panel.expanded{height:min(68%,620px)}.pdf-bottom-dock-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px 12px;border-bottom:1px solid rgba(120,88,62,.12)}.pdf-bottom-dock-header h3{margin:0;color:var(--color-text)}.pdf-bottom-dock-header p{margin:4px 0 0;color:var(--color-text-secondary);font-size:12px}.pdf-bottom-dock-actions{display:flex;align-items:center;gap:8px}.pdf-bottom-dock-search{width:220px;min-width:0;height:38px;border-radius:12px;border:1px solid rgba(120,88,62,.14);background:#ffffffe6;color:var(--color-text);padding:0 12px}.pdf-bottom-dock-action{width:38px;height:38px;border:1px solid rgba(120,88,62,.14);border-radius:12px;background:#ffffffe6;color:var(--color-text);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;line-height:1}.pdf-bottom-dock-table-wrap{flex:1;min-height:0;overflow:auto}.pdf-bottom-dock-table{width:100%;border-collapse:collapse;font-size:12.5px;color:var(--color-text)}.pdf-bottom-dock-table thead th{position:sticky;top:0;z-index:1;background:#f4e8dcfa;color:var(--color-text-secondary);text-align:left;font-weight:700;padding:10px 12px;border-bottom:1px solid rgba(120,88,62,.12);white-space:nowrap}.pdf-bottom-dock-table tbody td{padding:9px 12px;border-bottom:1px solid rgba(120,88,62,.08);vertical-align:top;white-space:nowrap}.pdf-bottom-dock-table tbody tr.clickable{cursor:pointer;-webkit-user-select:none;user-select:none}.pdf-bottom-dock-table tbody tr.clickable:hover{background:#2d6a4f14}.pdf-bottom-dock-table tbody tr.selected{background:#ea580c1a}.pdf-bottom-dock-empty{padding:24px;color:var(--color-text-secondary)}.pdf-bottom-dock-bulk-bar{display:flex;align-items:center;gap:10px;padding:8px 14px;background:#2d6a4f14;border-bottom:1px solid rgba(45,106,79,.18);font-size:13px;flex-shrink:0}.pdf-bottom-dock-bulk-bar span{flex:1;color:var(--color-text);font-weight:500}.pdf-bottom-dock-bulk-bar .pdf-submit-button{padding:5px 12px;font-size:12.5px}.pdf-bottom-dock-bulk-bar .pdf-submit-button.secondary{background:transparent;color:var(--color-text-secondary);border:1px solid rgba(120,88,62,.25)}.pivot-table .pivot-toggle{width:28px;text-align:center;font-weight:700;font-size:14px;color:var(--color-text-secondary);-webkit-user-select:none;user-select:none}.pivot-table .pivot-group{font-weight:600;background:#f4e8dc80}.pivot-table .pivot-group:hover{background:#f4e8dccc}.pivot-table .pivot-item td{font-weight:400;padding-left:14px;color:var(--color-text-secondary)}.pivot-table .pivot-item:hover{background:#2d6a4f14}.pivot-table .pivot-item.selected{background:#2d6a4f1f;color:var(--color-text)}.pdf-bottom-panel-nav{display:flex;align-items:center;gap:8px;margin-right:4px}.pdf-bottom-panel-button{width:42px;height:42px;border-radius:12px;border:1px solid var(--color-border-light);background:#fff;color:var(--color-text);display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.pdf-bottom-panel-button.selected{background:#277c3524;border-color:#277c353d;color:#214d38}.pdf-bottom-bar{height:74px;display:flex;align-items:center;gap:12px;padding:10px 16px;background:#fffaf6fa;color:var(--color-text);border-top:1px solid var(--color-border-light);flex-shrink:0}.pdf-bottom-nav,.pdf-bottom-button{height:42px;min-width:42px;border-radius:12px;border:1px solid var(--color-border-light);background:#fff;color:inherit;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.pdf-bottom-button.selected{background:#d46b3d1f;border-color:#d46b3d3d}.pdf-page-nav-group{display:flex;align-items:center;gap:12px;width:480px;flex-shrink:0}.pdf-bottom-label{flex:1;min-width:0;padding:0 14px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap;overflow:hidden}.pdf-bottom-label span{color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis}.pdf-bottom-label-pages{flex-shrink:0;color:inherit!important}.pdf-bottom-scale{min-width:92px;font-size:12px;line-height:1.35;color:var(--color-text-secondary)}.pdf-dim-control{margin-left:auto;display:flex;align-items:center;gap:10px;color:var(--color-text-secondary)}.pdf-dim-control input{width:160px}@media(max-width:1100px){.pdf-side-panel{width:300px;min-width:260px}.pdf-bottom-bar{flex-wrap:wrap;height:auto}.pdf-dim-control{width:100%;margin-left:0}.pdf-bottom-dock-search{width:160px}}@media(max-width:768px){.pdf-viewer-workspace{height:100vh;height:100dvh;min-height:100vh;min-height:100dvh}.pdf-workspace{position:relative;height:100%}.pdf-icon-rail{width:56px}.pdf-rail-button{width:38px;height:38px}.pdf-side-panel{position:absolute;left:56px;top:0;bottom:0;width:min(300px,calc(100vw - 56px));z-index:12}.pdf-bottom-bar{gap:8px;padding:10px 12px;justify-content:space-between;padding-bottom:calc(10px + env(safe-area-inset-bottom,0px))}.pdf-page-nav-group{width:auto;flex:1}.pdf-dim-control{display:none}.pdf-bottom-label>span:first-child{display:none}.pdf-bottom-scale{display:none}.pdf-bottom-button{min-width:38px;height:38px}.pdf-bottom-button--fit{display:none}.pdf-mobile-placement-dock{display:flex;flex-direction:column;bottom:calc(74px + env(safe-area-inset-bottom,0px))}.pdf-bottom-dock-panel{display:none}}.marker-link{position:absolute;overflow:visible;pointer-events:none;z-index:9}.marker-detached-label{position:absolute;transform:translate(-50%,-50%);border:2px solid;color:#fff;box-shadow:0 2px 8px #0000002e;cursor:pointer;display:flex;flex-direction:column;gap:2px;text-align:left;white-space:nowrap;z-index:10;transition:opacity .12s ease,box-shadow .12s ease,transform .12s ease}.marker-detached-label span{font-weight:700}.marker-drawing-inline-label{display:inline-flex;align-items:center;gap:0;white-space:nowrap;color:inherit;font:inherit}.marker-drawing-inline-label .marker-inline-prefix,.marker-drawing-inline-label .marker-inline-separator,.marker-drawing-inline-label .marker-inline-static,.marker-drawing-inline-label .marker-inline-readonly{color:inherit;font-weight:inherit;opacity:1}.marker-detached-label small{opacity:.9}.drawing-number-card{background:#fffaf5}.drawing-number-panel{margin-top:0;min-height:0;display:flex;flex-direction:column;gap:8px}.drawing-number-toolbar{display:flex;justify-content:flex-end}.drawing-number-close{width:34px;height:34px;border:none;border-radius:10px;background:var(--color-background-alt);color:var(--color-text);display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.drawing-number-version{display:inline-flex;margin-left:8px;padding:2px 8px;border-radius:999px;background:#d46b3d1f;font-size:12px}.drawing-number-header p{margin:4px 0 0;color:var(--color-text-secondary);line-height:1.35;font-size:13px}.drawing-number-progress{display:flex;flex-wrap:wrap;gap:8px}.drawing-number-progress span{border-radius:999px;padding:6px 10px;background:#d46b3d14;color:var(--color-text-secondary);font-size:12px}.drawing-number-progress span.active,.drawing-number-progress span.done{background:#c93b1742;color:var(--color-primary-dark)}.drawing-number-instructions{background:var(--color-background-alt);border-radius:12px;padding:12px 14px}.drawing-number-instructions p{margin:0;color:var(--color-text-secondary);line-height:1.5}.drawing-number-form{display:flex;flex-direction:column;gap:8px}.drawing-number-form.locked{opacity:.7}.drawing-number-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px 8px}.drawing-number-grid label,.drawing-number-toggle{display:flex;flex-direction:column;gap:3px;background:transparent;padding:0;justify-content:flex-start}.pdf-side-panel-content.info .drawing-number-grid label span,.pdf-side-panel-content.info .drawing-number-toggle>span,.pdf-side-panel-content.info .drawing-number-photos>span{color:var(--color-text-secondary);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;text-align:left}.feedback-panel{display:flex;flex-direction:column;gap:16px}.feedback-card{border:1px solid rgba(120,88,62,.12);border-radius:18px;background:linear-gradient(180deg,#fffcf8f5,#f8f1e9f0);padding:16px;box-shadow:0 10px 24px #78583e0f}.feedback-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}.feedback-card-header h4{margin:0 0 4px;font-size:.98rem}.feedback-card-header p{margin:0;color:var(--color-text-secondary);font-size:.85rem;line-height:1.4}.feedback-overview-pill{display:inline-flex;align-items:center;justify-content:center;min-height:30px;padding:0 12px;border-radius:999px;background:#bd232314;color:#8f1f1f;font-size:.75rem;font-weight:700;white-space:nowrap}.feedback-form-grid{display:flex;flex-direction:column;gap:12px}.feedback-form-grid label,.feedback-admin-tools label{display:flex;flex-direction:column;gap:6px;color:var(--color-text);font-size:.85rem}.feedback-form-grid label span,.feedback-admin-tools label span{font-weight:600}.feedback-form-grid input,.feedback-form-grid textarea,.feedback-admin-tools textarea,.feedback-admin-tools select{width:100%;border:1px solid rgba(120,88,62,.18);border-radius:12px;background:#ffffffeb;color:var(--color-text);padding:10px 12px;font:inherit}.feedback-file-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.feedback-file-list span{padding:4px 10px;border-radius:999px;background:#78583e17;font-size:.76rem}.feedback-card-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:12px}.feedback-error{margin-top:12px;padding:10px 12px;border-radius:12px;background:#bd232314;color:#8f1f1f;font-size:.85rem}.feedback-empty-state{padding:12px 0 4px;color:var(--color-text-secondary);font-size:.9rem}.feedback-thread-list{display:flex;flex-direction:column;gap:10px}.feedback-thread-button{width:100%;border:1px solid rgba(120,88,62,.12);border-radius:16px;background:#ffffffc7;padding:12px;display:flex;align-items:flex-start;justify-content:space-between;gap:10px;text-align:left;cursor:pointer;transition:border-color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast)}.feedback-thread-button:hover,.feedback-thread-button.selected{border-color:#d46b3d59;transform:translateY(-1px);box-shadow:0 10px 18px #78583e14}.feedback-thread-main{min-width:0;flex:1}.feedback-thread-title-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:6px}.feedback-thread-title-row strong{font-size:.9rem}.feedback-thread-meta{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:6px;color:var(--color-text-secondary);font-size:.75rem}.feedback-thread-main p{margin:0;color:var(--color-text-secondary);font-size:.82rem;line-height:1.4}.feedback-thread-unread{min-width:22px;height:22px;padding:0 6px;border-radius:999px;background:#c53030;color:#fff;font-size:.74rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center}.feedback-status-badge{display:inline-flex;align-items:center;justify-content:center;min-height:22px;padding:0 10px;border-radius:999px;font-size:.72rem;font-weight:700;background:#78583e1f;color:var(--color-text)}.feedback-message-list{display:flex;flex-direction:column;gap:12px}.feedback-message{border-radius:16px;padding:12px;background:#ffffffe6;border:1px solid rgba(120,88,62,.1)}.feedback-message.admin{background:#d46b3d14;border-color:#d46b3d29}.feedback-message.status{background:#236bbd14;border-color:#236bbd24}.feedback-message-header{display:flex;justify-content:space-between;gap:10px;margin-bottom:6px;font-size:.76rem}.feedback-message-header span{color:var(--color-text-secondary)}.feedback-message p{margin:0;white-space:pre-wrap;line-height:1.45;font-size:.86rem}.feedback-attachment-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}.feedback-attachment-link{width:92px;display:flex;flex-direction:column;gap:6px;color:var(--color-text);text-decoration:none;font-size:.72rem}.feedback-attachment-link img{width:92px;height:72px;object-fit:cover;border-radius:10px;border:1px solid rgba(120,88,62,.12);background:#fff}.feedback-admin-tools{display:flex;flex-direction:column;gap:12px;margin-top:16px;padding-top:16px;border-top:1px solid rgba(120,88,62,.12)}.feedback-inline-button{border:none;background:transparent;color:var(--color-primary-dark);cursor:pointer;font:inherit;font-weight:600}.global-feedback-widget{position:fixed;bottom:24px;right:24px;z-index:1200;display:flex;flex-direction:column;align-items:flex-end;gap:12px}.global-feedback-widget--pdf{bottom:90px}.global-feedback-button{width:54px;height:54px;border-radius:50%;background:var(--color-primary);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #00000038;position:relative;color:#fff;transition:background var(--transition-fast),transform var(--transition-fast);flex-shrink:0}.global-feedback-button:hover{background:var(--color-primary-dark);transform:scale(1.06)}.global-feedback-badge{position:absolute;top:-4px;right:-4px;background:#e53935;color:#fff;border-radius:999px;min-width:20px;height:20px;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 5px;border:2px solid #fff}.global-feedback-panel{width:420px;max-width:calc(100vw - 48px);max-height:calc(100vh - 120px);background:#fff;border-radius:16px;box-shadow:0 8px 32px #0000002e;display:flex;flex-direction:column;overflow:hidden}.global-feedback-panel-header{padding:14px 20px;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.global-feedback-panel-header h3{margin:0;font-size:1rem;font-weight:600}.global-feedback-panel-close,.global-feedback-panel-add{background:transparent;border:none;color:#fff;cursor:pointer;line-height:1;opacity:.85;transition:opacity var(--transition-fast)}.global-feedback-panel-close{font-size:22px;padding:0 2px}.global-feedback-panel-add{font-size:24px;padding:0 4px;font-weight:300}.global-feedback-panel-close:hover,.global-feedback-panel-add:hover{opacity:1}.global-feedback-panel-body{overflow-y:auto;flex:1;padding:16px;display:flex;flex-direction:column;gap:12px}@media(max-width:768px){.global-feedback-widget{bottom:80px;right:16px}.global-feedback-widget--pdf{bottom:140px}.global-feedback-panel{width:calc(100vw - 32px);max-width:none;max-height:55vh}.global-feedback-panel-header{padding:10px 14px}.global-feedback-panel-body{padding:10px;gap:8px}}.drawing-number-grid input,.drawing-number-grid select{width:100%;border:1px solid var(--color-border-light);background:#fff;color:var(--color-text);border-radius:10px;padding:7px 9px;min-height:34px;font-size:13px}.drawing-number-grid input:disabled{opacity:.55}.drawing-number-toggle{flex-direction:row;align-items:center;justify-content:space-between;min-height:28px}.drawing-number-switch{position:relative;width:52px;height:30px;display:inline-block}.drawing-number-switch input{opacity:0;width:0;height:0}.drawing-number-switch span{position:absolute;inset:0;background:#e3d5c7;border-radius:999px;cursor:pointer;transition:background var(--transition-fast)}.drawing-number-switch span:after{content:"";position:absolute;width:22px;height:22px;top:4px;left:4px;border-radius:50%;background:#fff;transition:transform var(--transition-fast)}.drawing-number-switch input:checked+span{background:var(--color-primary)}.drawing-number-switch input:checked+span:after{transform:translate(22px)}.drawing-number-photos{display:flex;flex-direction:column;gap:4px}.drawing-photo-upload{display:inline-flex;align-items:center;justify-content:center;padding:7px 10px;border-radius:12px;border:1px dashed var(--color-border);color:var(--color-text);background:#fff;cursor:pointer;font-size:12px}.drawing-photo-upload.disabled,.drawing-photo-chip:disabled{opacity:.5;cursor:not-allowed}.drawing-photo-upload input{display:none}.drawing-photo-list{display:flex;flex-wrap:wrap;gap:8px}.drawing-photo-chip{border:none;border-radius:999px;background:#d46b3d1a;color:var(--color-text);padding:5px 8px;cursor:pointer}.drawing-number-actions{display:flex;gap:8px;margin-top:0}.drawing-number-actions .pdf-submit-button{flex:1 1 0;padding:8px 10px;min-height:34px;font-size:12px}.annotation-editor-card{margin-top:0}.annotation-editor-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.annotation-color-picker{display:flex;flex-direction:column;gap:8px}.pdf-side-panel-content.info .annotation-color-picker>span{color:var(--color-text-secondary);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.annotation-color-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px}.annotation-color-swatch{width:100%;aspect-ratio:1;border-radius:10px;border:2px solid rgba(255,255,255,.85);box-shadow:0 0 0 1px #78583e24;cursor:pointer}.annotation-color-swatch.selected{box-shadow:0 0 0 2px #d46b3d99,0 0 0 1px #78583e24}.annotation-detail-panel{width:100%;min-width:0;overflow-y:scroll;max-height:calc(100dvh - 120px);-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.imported-float-panel{background:#fff;position:fixed;right:1rem;top:5rem;width:15rem;max-width:25%;box-shadow:2px 2px 4px #0000004d;border:1px solid rgba(81,127,157,.25);border-radius:.2rem;padding:.5rem 1rem .5rem .5rem;z-index:999;max-height:calc(100% - 5.5rem);overflow:auto;opacity:.95;font-size:.8rem}.imported-float-panel h4{margin:.5rem 0 .2rem;font-size:.85rem;font-weight:700;color:#1c1c1e}.imported-float-panel h4:first-child{margin-top:0}.imported-float-panel label{display:flex;justify-content:space-between;gap:8px;padding:2px 0;border-bottom:1px solid rgba(0,0,0,.06);color:#555;font-weight:400;font-size:.78rem}.imported-float-panel label span{color:#1c1c1e;font-weight:400;text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.imported-float-spacer{height:4px}.imported-float-actions{padding-top:.5rem}.imported-float-actions a{color:#c93b17;cursor:pointer;font-size:.78rem;text-decoration:none}.imported-float-actions a:hover{text-decoration:underline}.pdf-floating-panel.act{top:84px}.pdf-floating-panel-content label{display:flex;justify-content:space-between;gap:12px;padding:3px 0;border-bottom:1px solid rgba(120,88,62,.12);color:var(--color-text-secondary);font-size:.82rem}.pdf-floating-panel-content label span{color:var(--color-text);font-weight:600;text-align:right;white-space:nowrap}.detail-panel-status-select{border:1px solid var(--color-border-light);border-radius:4px;padding:1px 4px;font-size:.8rem;font-weight:600;color:var(--color-text);background:var(--color-background);cursor:pointer}.marker-detached-label-editing{padding:6px 10px;border-radius:999px;cursor:text}.marker-inline-editor{display:inline-flex;align-items:center;gap:0;white-space:nowrap;line-height:1.2}.marker-inline-prefix,.marker-inline-separator,.marker-inline-static{color:#111827;font-weight:700}.marker-inline-readonly{opacity:.72}.marker-inline-editor input{border:none;background:transparent;color:#111827;font:inherit;font-weight:700;min-width:1.6ch;padding:0;margin:0;outline:none;text-transform:uppercase}.marker-inline-editor input::selection{background:#d46b3d40}.annotation-detail-spacer{height:4px}.annotation-detail-actions{display:flex;flex-wrap:wrap;gap:8px;padding-top:6px}.annotation-detail-actions.stacked{flex-direction:column}.annotation-detail-link{border:none;background:transparent;color:var(--color-primary-dark);font-weight:600;padding:0;cursor:pointer}.annotation-detail-link.danger{color:#b42318}.annotation-detail-link.inline{display:inline;padding:0}.drawing-preview-pin{position:absolute;width:18px;height:18px;border-radius:50%;transform:translate(-50%,-50%);background:var(--color-primary);border:3px solid #fff;box-shadow:0 8px 16px #00000038}.drawing-preview-label{position:absolute;transform:translate(-50%,-50%);display:flex;align-items:center;white-space:nowrap;color:#fff;border:2px solid transparent;font-weight:700;box-shadow:0 12px 20px #0000002e}.drawing-preview-anchor{position:absolute;width:16px;height:16px;transform:translate(-50%,-50%);border:2px solid transparent;border-radius:999px;pointer-events:none;z-index:11}@media(max-width:768px){.pdf-floating-panel{top:76px;right:max(12px,env(safe-area-inset-right));left:max(12px,env(safe-area-inset-left));width:auto;max-width:none}.drawing-number-grid,.annotation-editor-grid{grid-template-columns:1fr}.annotation-color-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}.m-tekening-overlay{position:fixed;inset:0;z-index:10000;background:#000000d9;display:flex;align-items:center;justify-content:center}.m-tekening-modal{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden}.m-tekening-close{position:fixed;top:16px;right:16px;z-index:10001;width:44px;height:44px;border-radius:50%;border:none;background:#0009;color:#fff;font-size:28px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:background .15s}.m-tekening-close:hover{background:#fff3}.m-tekening-modal .react-transform-wrapper{width:100%!important;height:100%!important}.m-tekening-modal .react-pdf__Document{display:flex;justify-content:center}.m-tekening-modal .react-pdf__Page{box-shadow:0 4px 24px #0006}.compare-xlsx-modal{background:#fff;border-radius:10px;width:min(860px,95vw);max-height:min(80vh,600px);display:flex;flex-direction:column;box-shadow:0 8px 40px #00000040;overflow:hidden;align-self:center}.compare-xlsx-header{display:flex;align-items:center;justify-content:space-between;padding:.55rem 1rem;border-bottom:1px solid #e5e7eb;flex:0 0 auto}.compare-xlsx-header h2{font-size:.95rem;font-weight:600;margin:0}.compare-xlsx-ok{padding:.75rem 1rem;color:#16a34a;font-weight:500;font-size:.85rem}.compare-xlsx-body{flex:0 0 auto;overflow-y:auto;max-height:min(55vh,400px);padding:.5rem 1rem}.compare-xlsx-section-title{font-size:.78rem;font-weight:600;margin:0;line-height:1.3}.compare-xlsx-section-title.missing-in-app{color:#dc2626}.compare-xlsx-section-title.missing-in-excel,.compare-xlsx-section-title.status-changed{color:#d97706}.compare-xlsx-section-desc{font-size:.7rem;color:#6b7280;margin:0 0 .2rem;line-height:1.2}.compare-xlsx-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}.compare-xlsx-col-headers{display:flex;align-items:center;gap:.5rem;padding:0 .5rem;height:22px;font-size:.67rem;font-weight:700;color:#9ca3af;text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px}.compare-xlsx-col-headers span:first-child{flex:1 1 0;min-width:0}.compare-xlsx-col-headers span:nth-child(2),.compare-xlsx-col-headers span:nth-child(4){flex:0 0 120px;width:120px;text-align:center}.compare-xlsx-col-headers span:nth-child(3){flex:0 0 18px;width:18px}.compare-xlsx-list li{display:flex;align-items:center;gap:.5rem;height:30px;padding:0 .5rem;background:#f9fafb;border-radius:4px;flex-shrink:0}.compare-xlsx-subject{flex:1 1 0;min-width:0;font-family:monospace;font-size:.73rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.compare-xlsx-badge{flex-shrink:0;flex-grow:0;align-self:center;width:120px;max-width:120px;display:block;font-size:.68rem;padding:3px 6px;border-radius:3px;white-space:nowrap;font-weight:500;line-height:1.4;text-align:center;box-sizing:border-box;overflow:hidden}.compare-xlsx-badge.status{background:#f3f4f6;color:#374151;border:1px solid #d1d5db}.compare-xlsx-badge.app{background:#fef2f2;color:#b91c1c;border:1px solid #fca5a5}.compare-xlsx-badge.excel{background:#f0fdf4;color:#15803d;border:1px solid #86efac}.compare-xlsx-arrow{flex:0 0 18px;width:18px;color:#9ca3af;font-size:.7rem;text-align:center;line-height:1}.compare-xlsx-footer{display:flex;justify-content:flex-end;padding:.5rem 1rem;border-top:1px solid #e5e7eb;flex:0 0 auto}.m-tekening-error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca;border-radius:6px;padding:.5rem .75rem;font-size:.82rem;margin-bottom:.5rem}.admin-grid{display:grid;grid-template-columns:minmax(280px,360px) minmax(320px,1fr);gap:1rem;margin-bottom:1rem}.admin-card{background:#fff;border:1px solid #d7dde6;border-radius:14px;padding:1rem;box-shadow:0 10px 24px #0f172a0d}.admin-card-wide{margin-top:1rem}.admin-list{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem}.admin-list-item{display:flex;justify-content:space-between;align-items:center;gap:1rem;border:1px solid #d7dde6;background:#f8fafc;border-radius:10px;padding:.75rem;text-align:left;cursor:pointer}.admin-list-item.selected{border-color:#d46b3d;background:#fff5ef}.admin-member-list{display:flex;flex-direction:column;gap:.5rem;max-height:420px;overflow:auto;margin-bottom:1rem}.admin-checkbox-row{display:flex;align-items:center;gap:.75rem;border:1px solid #e2e8f0;border-radius:10px;padding:.75rem;background:#fff}.admin-checkbox-row span{display:flex;flex-direction:column;gap:.2rem}.admin-checkbox-row small{color:#64748b}.form-select-inline{min-width:160px;padding-right:2rem}.audit-code{display:block;max-width:460px;white-space:pre-wrap;word-break:break-word;font-size:.75rem;line-height:1.4;color:#334155}.role-permissions-table-wrap{overflow-x:auto}.role-permissions-table{min-width:900px}.role-permissions-table td:not(:first-child){text-align:center}@media(max-width:960px){.admin-grid{grid-template-columns:1fr}}@media(min-width:769px){.data-table{width:max(100%,540px);table-layout:fixed}.data-table thead{display:table-header-group}.data-table tbody tr{display:table-row}.data-table tbody tr td{padding:10px 14px;border-bottom:1px solid var(--color-border-light);border:revert}}@media(min-width:769px)and (max-width:1024px){.pdf-bottom-scale{display:none}.pdf-bottom-label>span:first-child{display:none}.header{padding:0 20px;gap:20px}.main{padding:20px}.search-input{width:220px}.page-header{flex-wrap:wrap;gap:12px}.page-header-actions{flex-wrap:wrap}.pdf-page-nav-group{width:auto;flex:1}.pdf-bottom-dock-search{width:150px}.pdf-side-panel{width:min(300px,38vw);min-width:260px}.admin-grid{grid-template-columns:1fr}.detail-info{grid-template-columns:repeat(2,1fr)}}@media(hover:none)and (pointer:coarse){.pdf-doc-hover-actions{display:flex!important;flex-wrap:wrap;gap:8px 16px;border-top:1px solid var(--color-border-light);margin-top:10px;padding:8px 0 0}.btn{min-height:44px;padding:10px 18px}.btn-sm{min-height:40px;padding:8px 14px}.header-nav a{padding:10px 14px;min-height:44px;display:inline-flex;align-items:center}.marker-menu-item{padding:12px 16px;min-height:44px}.pdf-overflow-item{padding:14px 16px;min-height:44px}.pdf-doc-item{padding:14px 16px}.pdf-bookmark-item{padding:12px 14px;margin-bottom:6px}.data-table td{padding:13px 14px}.admin-list-item,.admin-checkbox-row{padding:1rem}.checklist-item{padding:18px 0}.form-input,.search-input{min-height:44px;padding:10px 14px}::-webkit-scrollbar{width:3px;height:3px}.annotation-detail-panel{max-height:calc(100dvh - 110px)}.annotation-detail-panel.pdf-floating-panel-content{padding:8px 10px}.pdf-floating-panel-content h4{font-size:.68rem;margin-top:2px;margin-bottom:0}.pdf-floating-panel-content label{font-size:.68rem;padding:1px 0;gap:6px}.annotation-detail-panel .pdf-submit-button{padding:4px 10px;font-size:.72rem;border-radius:6px;margin-bottom:3px!important;min-height:0}.drawing-number-panel{gap:4px}.annotation-detail-spacer{height:2px}.annotation-detail-actions{gap:5px;padding-top:3px}.annotation-detail-link{font-size:.72rem}.detail-panel-status-select{font-size:.68rem}}@media(max-width:768px){.login-card{padding:40px 24px;margin:16px;max-width:calc(100vw - 32px);border-radius:var(--radius-md)}.pdf-doc-hover-actions{display:flex!important;flex-wrap:wrap;gap:8px 12px}.pdf-doc-hover-actions a{min-height:36px;display:inline-flex;align-items:center;padding:4px 0}.table-container,.favorites-section__scroll{-webkit-overflow-scrolling:touch}.data-table{width:100%;table-layout:auto}.data-table thead{display:none}.data-table tbody tr{display:grid;grid-template-columns:1fr auto;grid-template-rows:auto auto;gap:4px 12px;padding:12px 14px;border-bottom:1px solid var(--color-border-light)}.data-table tbody tr:last-child{border-bottom:none}.data-table tbody tr td{padding:0;border:none;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.data-table tbody tr td:nth-child(1){grid-column:1;grid-row:1;font-weight:600;font-size:14px}.data-table tbody tr td:nth-child(2){grid-column:1;grid-row:2;font-size:12.5px;color:var(--color-text-secondary)}.data-table tbody tr td:nth-child(3){grid-column:2;grid-row:1;text-align:right;font-size:12.5px;color:var(--color-text-secondary);white-space:nowrap}.data-table tbody tr td:nth-child(4){grid-column:2;grid-row:2;text-align:right;align-self:center}.orders-table colgroup{display:none}.orders-table,.orders-table tbody{display:block;width:100%}.orders-table tbody tr{width:100%;grid-template-columns:minmax(0,1fr) max-content;align-items:center}.orders-table tbody tr td{min-width:0}.orders-table .orders-table__number{display:flex;align-items:center;gap:2px}.orders-table .orders-table__project{max-width:100%}.orders-table .orders-table__date,.orders-table .orders-table__access{justify-self:end}.audit-table{display:block;width:100%}.audit-table tbody{display:flex;flex-direction:column;width:100%}.audit-table tbody tr{display:grid;grid-template-columns:1fr;gap:8px;width:100%;padding:14px;border-bottom:1px solid var(--color-border-light)}.audit-table tbody tr td{display:grid;grid-template-columns:86px minmax(0,1fr);gap:10px;min-width:0;white-space:normal;text-overflow:clip}.audit-table tbody tr td:before{content:attr(data-label);color:var(--color-text-muted);font-family:var(--font-heading);font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.audit-table tbody tr td[data-label=Actie],.audit-table tbody tr td[data-label=Gebruiker]{align-items:start}.audit-table tbody tr td[data-label=Details]{display:block}.audit-table tbody tr td[data-label=Details]:before{display:block;margin-bottom:6px}.audit-table .audit-code{max-width:none;width:100%;padding:10px;border-radius:var(--radius-sm);background:var(--color-background);white-space:pre-wrap;overflow-wrap:anywhere;word-break:break-word}.role-permissions-table-wrap{overflow-x:visible}.role-permissions-table{display:block;min-width:0;width:100%}.role-permissions-table tbody{display:flex;flex-direction:column;gap:12px;width:100%}.role-permissions-table tbody tr{display:grid;grid-template-columns:1fr;gap:0;width:100%;padding:0;overflow:hidden;border:1px solid var(--color-border-light);border-radius:var(--radius-md);background:var(--color-surface)}.role-permissions-table tbody tr td{display:flex;align-items:center;justify-content:space-between;gap:12px;min-width:0;min-height:44px;padding:10px 12px;border-bottom:1px solid var(--color-border-light);white-space:normal;text-align:left}.role-permissions-table tbody tr td:first-child{background:var(--color-background);font-size:15px}.role-permissions-table tbody tr td:last-child{border-bottom:none}.role-permissions-table tbody tr td:before{content:attr(data-label);color:var(--color-text-secondary);font-family:var(--font-heading);font-size:12px;font-weight:600}.role-permissions-table tbody tr td:first-child:before,.role-permissions-table .role-permissions-table__actions:before{content:none}.role-permissions-table input[type=checkbox]{width:22px;height:22px;flex:0 0 auto}.role-permissions-table .role-permissions-table__actions{justify-content:flex-end;padding-top:12px;padding-bottom:12px}.pagination{justify-content:center}.pagination span{width:100%;text-align:center}.pdf-bottom-bar{padding-bottom:max(10px,env(safe-area-inset-bottom,10px))}.modal-card{width:calc(100vw - 32px);max-width:100%;margin:16px}.admin-card{padding:.75rem}.opleveren-card{padding:16px}}@media(min-width:600px)and (max-width:768px){.page-header{flex-direction:row;align-items:center;flex-wrap:wrap}.page-header-actions{flex-direction:row;align-items:center;flex-wrap:wrap;width:auto}.search-input{width:200px}}
