:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;--main-bg-color: #ffffff;--main-fg-color: #213547;--controls-bg-color: #f0f0f0;--controls-fg-color: #213547;--button-bg-color: #e9e9e9;--button-fg-color: #213547;--button-border-color: #cccccc;--input-bg-color: #ffffff;--input-fg-color: #213547;--input-border-color: #b0b0b0;--pdf-panel-bg: #e0e0e0;--rsvp-panel-bg: #ffffff;--rsvp-text-color: #000000;--rsvp-bg-color: #ffffff;--status-bg-color: #e0e0e0;--settings-bg-color: #f9f9f9;--progress-trough-color: #d0d0d0;--progress-bar-color: #0078d4;--border-color: #cccccc;--border-color-light: #eeeeee;--focus-outline-color: #005a9e;--info-bg-color: #eef6fc;--info-fg-color: #005a9e;--error-bg-color: #fdecea;--error-fg-color: #a51c00;--error-border-color: #e99080;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme: dark){:root:not(.high-contrast){--main-bg-color: #1e1e1e;--main-fg-color: #d4d4d4;--controls-bg-color: #2a2a2a;--controls-fg-color: #d4d4d4;--button-bg-color: #3c3c3c;--button-fg-color: #f0f0f0;--button-border-color: #505050;--input-bg-color: #2c2c2c;--input-fg-color: #d4d4d4;--input-border-color: #606060;--pdf-panel-bg: #252526;--rsvp-panel-bg: #121212;--rsvp-text-color: #ffffff;--rsvp-bg-color: #121212;--status-bg-color: #2a2a2a;--settings-bg-color: #252525;--progress-trough-color: #3a3a3a;--progress-bar-color: #0090f0;--border-color: #444444;--border-color-light: #333333;--focus-outline-color: #00aaff;--info-bg-color: #2a3a4a;--info-fg-color: #90c0ef;--error-bg-color: #4a2a2a;--error-fg-color: #f0a090;--error-border-color: #c07060}}body{margin:0;background-color:var(--main-bg-color);color:var(--main-fg-color);transition:background-color .3s,color .3s}button,input,select,textarea{font-family:inherit;font-size:.95em;padding:.5em .8em;border-radius:4px;border:1px solid var(--input-border-color);background-color:var(--input-bg-color);color:var(--input-fg-color);transition:border-color .2s,background-color .2s}button{background-color:var(--button-bg-color);color:var(--button-fg-color);border-color:var(--button-border-color);cursor:pointer;font-weight:500}button:hover:not(:disabled){border-color:var(--focus-outline-color);filter:brightness(1.1)}button:disabled{opacity:.6;cursor:not-allowed}input[type=color]{padding:0;min-width:40px;height:28px}input[type=checkbox]{width:auto;height:auto;margin-right:4px;vertical-align:middle}*:focus-visible{outline:3px solid var(--focus-outline-color);outline-offset:1px;box-shadow:0 0 0 2px var(--main-bg-color)}.high-contrast *:focus-visible{outline:3px solid var(--focus-outline-color);box-shadow:0 0 0 2px var(--main-bg-color)}.visually-hidden{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;white-space:nowrap}#root{margin:0 auto;text-align:center}.app-container{display:flex;flex-direction:column;height:100vh;width:100vw;overflow:hidden;background-color:var(--main-bg-color);color:var(--main-fg-color)}.top-bar{padding:10px 15px;border-bottom:1px solid var(--border-color, #ccc);background-color:var(--controls-bg-color, #f0f0f0);display:flex;flex-wrap:wrap;gap:15px;align-items:center;justify-content:space-between}.main-controls-group{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.top-bar button,.top-bar input,.top-bar select{margin-right:5px}.loading-message,.error-message{padding:10px;text-align:center;font-weight:700}.loading-message{background-color:var(--info-bg-color, #eef);color:var(--info-fg-color, #33a)}.error-message{background-color:var(--error-bg-color, #fee);color:var(--error-fg-color, #a33);border:1px solid var(--error-border-color, #d99)}.main-content{display:flex;flex-grow:1;overflow:hidden}.pdf-panel{width:35%;min-width:300px;border-right:1px solid var(--border-color, #ccc);display:flex;flex-direction:column;overflow-y:auto;background-color:var(--pdf-panel-bg, #e9e9e9)}.rsvp-main-panel{flex-grow:1;display:flex;flex-direction:column;align-items:center;padding:20px;overflow-y:auto;background-color:var(--rsvp-panel-bg, #ffffff)}.rsvp-panel{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;flex-grow:1;min-height:200px}.status-bar{padding:8px 15px;border-top:1px solid var(--border-color, #ccc);background-color:var(--status-bg-color, #e0e0e0);font-size:.9em;text-align:left}.progress-bar-container{width:100%;height:8px;background-color:var(--progress-trough-color, #e0e0e0)}.progress-bar-fill{height:100%;background-color:var(--progress-bar-color, #0078d7);transition:width .1s linear}.settings-panel-container{width:100%;max-width:600px;margin-top:20px;padding:15px;border:1px solid var(--border-color, #ccc);border-radius:8px;background-color:var(--settings-bg-color, #f9f9f9)}.settings-panel-container h3{margin-top:0;margin-bottom:15px;border-bottom:1px solid var(--border-color-light, #eee);padding-bottom:5px}.setting-group{margin-bottom:12px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.setting-group label{margin-right:5px;white-space:nowrap}.setting-group input[type=number]{width:70px;padding:4px;border:1px solid var(--input-border-color);background-color:var(--input-bg-color);color:var(--input-fg-color)}.setting-group input[type=color]{width:40px;height:25px;padding:0;border:1px solid var(--input-border-color, #ccc);background-color:transparent;cursor:pointer}.setting-group input[type=checkbox]{width:16px;height:16px}.setting-group input[type=range]{flex-grow:1}.high-contrast{--main-bg-color: #000000;--main-fg-color: #ffffff;--controls-bg-color: #1a1a1a;--controls-fg-color: #ffffff;--button-bg-color: #333333;--button-fg-color: #ffffff;--button-border-color: #ffffff;--input-bg-color: #222222;--input-fg-color: #ffffff;--input-border-color: #ffffff;--pdf-panel-bg: #0a0a0a;--rsvp-panel-bg: #000000;--rsvp-text-color: #ffff00;--rsvp-bg-color: #000000;--status-bg-color: #1a1a1a;--settings-bg-color: #111111;--progress-trough-color: #555555;--progress-bar-color: #ffff00;--border-color: #666666;--border-color-light: #444444;--focus-outline-color: #ffff00;--info-bg-color: #334;--info-fg-color: #ccf;--error-bg-color: #433;--error-fg-color: #fcc;--error-border-color: #c99}.high-contrast .pdf-panel{border-right:1px solid var(--border-color)}.high-contrast .settings-panel-container{border:1px solid var(--border-color)}.high-contrast .settings-panel-container h3{border-bottom:1px solid var(--border-color-light)}.high-contrast .rsvp-word-container{border:1px solid var(--rsvp-text-color)}*:focus-visible{outline:3px solid var(--focus-outline-color, #0078d7);outline-offset:1px;box-shadow:0 0 0 2px var(--main-bg-color, white)}.ambient-sound-player h4{margin-top:0;margin-bottom:10px}.ambient-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.ambient-controls select,.ambient-controls button,.ambient-controls input[type=range]{padding:4px 8px}.ambient-controls label{white-space:nowrap}.controls-container{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.wpm-control{display:flex;align-items:center;gap:5px}.wpm-control label{white-space:nowrap}.wpm-number-input{width:65px;padding:4px;border:1px solid var(--input-border-color);background-color:var(--input-bg-color);color:var(--input-fg-color)}.wpm-control input[type=range]{min-width:100px}.pdf-viewer-container{display:flex;flex-direction:column;height:100%}.pdf-controls{padding:8px;background-color:var(--controls-bg-color);border-bottom:1px solid var(--border-color);display:flex;gap:8px;align-items:center;flex-wrap:wrap}.pdf-document-wrapper{flex-grow:1;overflow:auto;display:flex;justify-content:center;padding:10px 0;background-color:var(--pdf-panel-bg)}.pdf-document-wrapper .react-pdf__Page__canvas{box-shadow:0 0 8px #0000004d;margin:0 auto}.high-contrast .pdf-document-wrapper .react-pdf__Page__canvas{box-shadow:0 0 5px var(--border-color)}.pdf-placeholder,.pdf-loading,.pdf-error{display:flex;align-items:center;justify-content:center;height:100%;padding:20px;font-style:italic;color:var(--main-fg-color);opacity:.7}.pdf-error{color:var(--error-fg-color);font-weight:700;opacity:1}.rsvp-word-container{min-height:100px;min-width:250px;max-width:90%;padding:20px 30px;border:1px solid var(--border-color);border-radius:6px;text-align:center;font-weight:700;display:flex;align-items:center;justify-content:center;transition:background-color .3s,color .3s,border-color .3s;box-shadow:0 2px 5px #0000001a;word-break:break-all}.high-contrast .rsvp-word-container{box-shadow:0 1px 3px #c8c80033}.page-turn-notification{position:fixed;bottom:60px;left:50%;transform:translate(-50%);background-color:var(--info-bg-color, #d1ecf1);color:var(--info-fg-color, #0c5460);padding:8px 15px;border-radius:4px;box-shadow:0 2px 5px #00000026;z-index:1050;font-size:.9em;font-weight:700;text-align:center;border:1px solid var(--info-border-color, #bee5eb);animation:fadeInOut 1.5s ease-in-out}@keyframes fadeInOut{0%{opacity:0;transform:translate(-50%) translateY(10px)}20%{opacity:1;transform:translate(-50%) translateY(0)}80%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(10px)}}.high-contrast .page-turn-notification{background-color:var(--info-bg-color);color:var(--info-fg-color);border-color:var(--info-border-color);box-shadow:0 0 5px var(--border-color)}:root{--info-border-color: #bee5eb}.high-contrast{--info-border-color: #6fb3c0}.ambient-sound-player{margin-top:20px;padding-top:15px;border-top:1px solid var(--border-color-light, #eee)}.high-contrast .ambient-sound-player{border-top:1px solid var(--border-color-light)}.ambient-sound-player h4{margin-top:0;margin-bottom:15px}.ambient-sound-control-group{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;padding:8px;border-radius:4px;background-color:var(--controls-bg-color, #f8f9fa);border:1px solid var(--border-color, #dee2e6)}.high-contrast .ambient-sound-control-group{background-color:var(--controls-bg-color);border:1px solid var(--border-color)}.ambient-sound-name{flex-grow:1;margin-right:10px;font-weight:500}.ambient-controls-inline{display:flex;align-items:center;gap:10px}.ambient-controls-inline button{padding:4px 8px;min-width:70px}.ambient-controls-inline input[type=range]{width:100px}: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(--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{-webkit-appearance:none;-moz-appearance:none;appearance:none}.annotationLayer .popupTriggerArea{height:100%;width:100%}.annotationLayer .fileAttachmentAnnotation .popupTriggerArea{position:absolute}.annotationLayer .popupWrapper{position:absolute;font-size:calc(9px * var(--scale-factor));width:100%;min-width:calc(180px * var(--scale-factor));pointer-events:none}.annotationLayer .popup{position:absolute;max-width:calc(180px * var(--scale-factor));background-color:#ff9;box-shadow:0 calc(2px * var(--scale-factor)) calc(5px * var(--scale-factor)) #888;border-radius:calc(2px * var(--scale-factor));padding:calc(6px * var(--scale-factor));margin-left:calc(5px * var(--scale-factor));cursor:pointer;font:message-box;white-space:normal;word-wrap:break-word;pointer-events:auto}.annotationLayer .popup>*{font-size:calc(9px * var(--scale-factor))}.annotationLayer .popup h1{display:inline-block}.annotationLayer .popupDate{display:inline-block;margin-left:calc(5px * var(--scale-factor))}.annotationLayer .popupContent{border-top:1px solid rgba(51,51,51,1);margin-top:calc(2px * var(--scale-factor));padding-top:calc(2px * var(--scale-factor))}.annotationLayer .richText>*{white-space:pre-wrap;font-size:calc(9px * var(--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;top:0;right:0;bottom:0;left: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;top:100%;right:0;bottom:0;left: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}
