:root{--primary:#007aff;--primary-hover:#0056cc;--primary-muted:#007aff1a;--bg-app:#f2f2f7;--bg-grouped:#fff;--card-bg:#fff;--bg-secondary:#fff;--bg-tertiary:#f2f2f7;--card-border:#3c3c431f;--separator:#3c3c431f;--text-primary:#000;--text-secondary:#3c3c43;--text-tertiary:#8e8e93;--text-quaternary:#c7c7cc;--accent:#34c759;--accent-muted:#34c7591f;--danger:#ff3b30;--orange:#ff9500;--nav-bg:#f9f9f9f0;--shadow-sm:0 1px 3px #0000000a;--shadow:0 2px 8px #0000000f;--shadow-lg:0 4px 16px #00000014}[data-theme=dark]{--primary:#0a84ff;--primary-hover:#409cff;--primary-muted:#0a84ff26;--bg-app:#000;--bg-grouped:#1c1c1e;--card-bg:#1c1c1e;--bg-secondary:#1c1c1e;--bg-tertiary:#2c2c2e;--card-border:#ffffff14;--separator:#545458a6;--text-primary:#fff;--text-secondary:#ebebf5;--text-tertiary:#8e8e93;--text-quaternary:#48484a;--accent:#30d158;--accent-muted:#30d15826;--danger:#ff453a;--orange:#ff9f0a;--nav-bg:#1d1d1ff0;--shadow-sm:none;--shadow:none;--shadow-lg:none}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}html{font-size:16px}body{color:var(--text-primary);background-color:var(--bg-app);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,SF Pro Display,Helvetica Neue,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.47;transition:background-color .3s,color .3s;overflow-x:hidden}.ios-card,.ios-group{background:var(--card-bg);box-shadow:var(--shadow-sm);border-radius:10px;transition:background-color .3s;overflow:hidden}.ios-group-header{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.02em;padding:0 1rem .375rem;font-size:.8125rem;font-weight:400}.ios-row{align-items:center;gap:.75rem;min-height:44px;padding:.6875rem 1rem;display:flex;position:relative}.ios-row+.ios-row{border-top:1px solid var(--separator);margin-left:1rem;padding-left:0}.ios-row-label{flex:1;font-size:1.0625rem}.ios-row-detail{color:var(--text-tertiary);font-size:1.0625rem}.ios-row-chevron{color:var(--text-quaternary);flex-shrink:0}.ios-input-row{flex-direction:column;gap:.125rem;min-height:44px;padding:.5rem 1rem;display:flex}.ios-input-row+.ios-input-row{border-top:1px solid var(--separator)}.ios-input-row label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;font-size:.6875rem;font-weight:600}.ios-input-row input,.ios-input-row textarea{width:100%;color:var(--text-primary);box-shadow:none;background:0 0;border:none;border-radius:0;outline:none;padding:.375rem 0;font-family:inherit;font-size:1.0625rem}.ios-input-row textarea{resize:vertical;min-height:3rem}.ios-input-row input::placeholder,.ios-input-row textarea::placeholder{color:var(--text-quaternary)}.ios-segment{background:var(--card-border);border-radius:8px;width:100%;max-width:100%;margin-left:auto;margin-right:auto;padding:2px;display:flex}.ios-segment-btn{color:var(--text-primary);cursor:pointer;white-space:nowrap;text-overflow:ellipsis;background:0 0;border:none;border-radius:7px;flex:1;padding:.4375rem .5rem;font-size:.8125rem;font-weight:600;transition:all .2s;position:relative;overflow:hidden}.ios-segment-btn.active{background:var(--card-bg);box-shadow:0 1px 3px #00000014,0 1px 2px #0000000f}.header-logo-img{object-fit:contain;width:auto;max-height:40px;display:block}button.header-back{cursor:pointer;background:0 0;border:none;align-items:center;display:flex}.btn{cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:.375rem;padding:.75rem 1.25rem;font-family:inherit;font-size:1.0625rem;font-weight:600;transition:all .15s;display:inline-flex}.btn:active{opacity:.85;transform:scale(.97)}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-secondary{background:var(--primary-muted);color:var(--primary)}.btn-outline{background:var(--card-bg);border:1px solid var(--card-border);color:var(--primary);box-shadow:var(--shadow-sm);font-weight:400}.btn-danger-text{color:var(--danger);background:0 0;border:none;font-weight:400}.btn-sm{border-radius:8px;padding:.375rem .75rem;font-size:.875rem}.btn-icon{color:var(--primary);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:.5rem;transition:opacity .15s;display:inline-flex}.btn-icon:active{opacity:.6}input[type=text],input[type=date],textarea{background:var(--bg-app);border:1px solid var(--card-border);width:100%;color:var(--text-primary);border-radius:10px;padding:.75rem 1rem;font-family:inherit;font-size:1rem;transition:border-color .2s,background-color .3s}textarea{resize:vertical;min-height:80px}input:focus,textarea:focus{border-color:var(--primary);outline:none}.ios-toggle{flex-shrink:0;width:51px;height:31px;position:relative}.ios-toggle input{opacity:0;width:0;height:0}.ios-toggle-track{cursor:pointer;background:var(--text-quaternary);border-radius:31px;transition:background .25s;position:absolute;inset:0}.ios-toggle-track:before{content:"";background:#fff;border-radius:50%;width:27px;height:27px;transition:transform .25s;position:absolute;bottom:2px;left:2px;box-shadow:0 1px 3px #00000026}.ios-toggle input:checked+.ios-toggle-track{background:var(--accent)}.ios-toggle input:checked+.ios-toggle-track:before{transform:translate(20px)}.badge{border-radius:6px;align-items:center;gap:.25rem;padding:.1875rem .5rem;font-size:.75rem;font-weight:600;display:inline-flex}.badge-primary{background:var(--primary-muted);color:var(--primary);border:1px solid #007aff4d}.badge-accent{background:var(--accent-muted);color:var(--accent);border:1px solid #34c7594d}.badge-success{color:var(--accent);background:#34c7591f;border:1px solid #34c7594d}.badge-warning{color:var(--orange);background:#ff95001f;border:1px solid #ff95004d}.badge-muted{color:var(--text-tertiary);background:#8e8e931f;border:1px solid #8e8e934d}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.animate-slide-up{animation:.35s cubic-bezier(.25,1,.5,1) forwards slideUp}.animate-fade-in{animation:.3s forwards fadeIn}.animate-scale-in{animation:.3s cubic-bezier(.25,1,.5,1) forwards scaleIn}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}.text-accent{color:var(--accent)}.text-danger{color:var(--danger)}.text-primary-color{color:var(--primary)}.flex{display:flex}.flex-col{flex-direction:column;display:flex}.flex-1{flex:1}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.text-center{text-align:center}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.pt-2{padding-top:.5rem}.pb-2{padding-bottom:.5rem}.w-full{width:100%}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-lg{font-size:1.125rem}.opacity-50{opacity:.5}.cursor-pointer{cursor:pointer}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:1s linear infinite spin}.app-container{background-color:var(--bg-app);flex-direction:column;max-width:430px;min-height:100dvh;margin:0 auto;display:flex;position:relative}.header{z-index:50;background:var(--nav-bg);-webkit-backdrop-filter:saturate(180%)blur(4px);border-bottom:.5px solid var(--separator);justify-content:space-between;align-items:center;min-height:44px;padding:.75rem 1rem;display:flex;position:sticky;top:0}.header-title{letter-spacing:-.01em;white-space:nowrap;text-overflow:ellipsis;max-width:60%;margin:0;font-size:1.0625rem;font-weight:600;position:absolute;left:50%;overflow:hidden;transform:translate(-50%)}.header-left,.header-right{z-index:1;align-items:center;gap:.25rem;display:flex}.header-back{color:var(--primary);cursor:pointer;background:0 0;border:none;align-items:center;gap:.125rem;padding:0;font-family:inherit;font-size:1.0625rem;display:inline-flex}.header-back:active{opacity:.5}.page-title{letter-spacing:-.03em;margin-bottom:.25rem;font-size:2rem;font-weight:700;line-height:1.2}.main-content{flex-direction:column;flex:1;gap:1rem;padding:1rem 1rem 2rem;display:flex}.main-content.has-fab{padding-bottom:6rem}.checklist-card{cursor:pointer;padding:.875rem 1rem;transition:transform .12s}.checklist-card:active{opacity:.85;transform:scale(.98)}.checklist-card+.checklist-card{border-top:1px solid var(--separator)}.project-card{cursor:pointer;align-items:center;gap:.75rem;padding:.875rem 1rem;transition:transform .12s;display:flex}.project-card:active{opacity:.85;transform:scale(.98)}.project-card+.project-card{border-top:1px solid var(--separator)}.project-icon{color:#fff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1rem;font-weight:700;display:flex}.progress-bar{background:var(--card-border);border-radius:2px;height:3px;margin-top:.5rem;overflow:hidden}.progress-fill{background:var(--primary);border-radius:2px;height:100%;transition:width .35s}.progress-fill.completed{background:var(--accent)}.camera-input-container{width:100%;display:inline-block;position:relative;overflow:hidden}.camera-input-container input[type=file]{opacity:0;cursor:pointer;z-index:10;width:100%;height:100%;position:absolute;top:0;left:0}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:.375rem;display:grid}.photo-thumbnail-wrap{aspect-ratio:1;position:relative}.photo-thumbnail{object-fit:cover;border-radius:6px;width:100%;height:100%}.photo-remove{background:var(--danger);border:2px solid var(--card-bg);color:#fff;cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;padding:0;font-size:.625rem;line-height:1;display:flex;position:absolute;top:-4px;right:-4px}.fab{z-index:40;border-radius:14px;max-width:400px;padding:.875rem 2rem;position:fixed;bottom:2rem;left:50%;transform:translate(-50%);box-shadow:0 4px 20px #007aff59,0 2px 8px #0000001a}.fab:active:not(:disabled){transform:translate(-50%)scale(.97)}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:3rem 2rem;display:flex}.empty-state-icon{background:var(--card-border);width:56px;height:56px;color:var(--text-tertiary);border-radius:50%;justify-content:center;align-items:center;margin-bottom:.25rem;display:flex}.meta-row{justify-content:space-between;align-items:center;padding:.6875rem 0;display:flex}.meta-row+.meta-row{border-top:1px solid var(--separator)}.meta-label{color:var(--text-primary);font-size:.9375rem}.meta-value{color:var(--text-tertiary);font-size:.9375rem}.success-view{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:.5rem;min-height:60vh;display:flex}.success-icon{background:var(--accent);border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin-bottom:.75rem;display:flex;box-shadow:0 6px 20px #34c75959}.lightbox-overlay{z-index:100;-webkit-backdrop-filter:blur(4px)saturate(180%);backdrop-filter:blur(4px)saturate(180%);background:#00000073;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}:root .lightbox-overlay{background:#00000059}[data-theme=dark] .lightbox-overlay{background:#0000008c}.lightbox-image{object-fit:contain;-webkit-user-select:none;user-select:none;border-radius:8px;max-width:90vw;max-height:80vh;animation:.25s cubic-bezier(.25,1,.5,1) scaleIn}.lightbox-close{color:#fff;cursor:pointer;z-index:101;background:#ffffff26;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:background .15s;display:flex;position:absolute;top:1rem;right:1rem}.lightbox-close:active{background:#ffffff4d}.lightbox-counter{color:#ffffffb3;z-index:101;font-size:.8125rem;font-weight:600;position:absolute;top:1.25rem;left:50%;transform:translate(-50%)}.lightbox-nav{color:#fff;cursor:pointer;z-index:101;background:#ffffff1f;border:none;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;transition:background .15s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.lightbox-nav:active{background:#ffffff40}.lightbox-nav-prev{left:.75rem}.lightbox-nav-next{right:.75rem}.confirm-overlay{z-index:500;-webkit-backdrop-filter:blur(4px)saturate(180%);backdrop-filter:blur(4px)saturate(180%);background:#00000059;justify-content:center;align-items:center;padding:1rem;animation:.15s fadeIn;display:flex;position:fixed;inset:0}:root .confirm-overlay{background:#00000040}[data-theme=dark] .confirm-overlay{background:#00000080}.confirm-dialog{background:var(--card-bg);text-align:center;border-radius:14px;width:100%;max-width:270px;animation:.2s cubic-bezier(.25,1,.5,1) scaleIn;overflow:hidden;box-shadow:0 8px 40px #00000040}.confirm-body{padding:1.25rem 1rem .75rem}.confirm-title{margin-bottom:.375rem;font-size:1.0625rem;font-weight:600}.confirm-message{color:var(--text-tertiary);font-size:.8125rem;line-height:1.4}.confirm-actions{border-top:.5px solid var(--separator);display:flex}.confirm-btn{cursor:pointer;background:0 0;border:none;flex:1;padding:.75rem;font-family:inherit;font-size:1.0625rem;transition:background .1s}.confirm-btn:active{background:var(--card-border)}.confirm-btn+.confirm-btn{border-left:.5px solid var(--separator)}.confirm-btn-cancel{color:var(--primary);font-weight:400}.confirm-btn-danger{color:var(--danger);font-weight:600}@media (width>=768px){.app-container{border-left:.5px solid var(--separator);border-right:.5px solid var(--separator);max-width:680px}.main-content{padding:1.5rem 2rem}.page-title{font-size:2.25rem}.header{padding:.875rem 2rem}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(96px,1fr))}.project-icon{border-radius:12px;width:48px;height:48px}.confirm-dialog{max-width:320px}.fab{max-width:480px}}@media (width>=1024px){body{background:var(--bg-app)}.app-container{max-width:780px;min-height:100vh;box-shadow:0 0 60px #00000014}[data-theme=dark] .app-container{box-shadow:0 0 60px #0000004d}.main-content{padding:2rem 2.5rem}.header{min-height:52px;padding:1rem 2.5rem}.header-title{font-size:1.125rem}.page-title{font-size:2.5rem}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:.5rem}.checklist-card{padding:1rem 1.25rem}.project-card{gap:1rem;padding:1rem 1.25rem}.project-icon{border-radius:14px;width:52px;height:52px;font-size:1.125rem}.meta-row{padding:.75rem 0}.confirm-dialog{max-width:360px}.ios-segment{max-width:100%;margin-left:auto;margin-right:auto}.fab{max-width:520px;bottom:2.5rem}.checklist-card:hover,.project-card:hover{background:var(--primary-muted)}.btn:hover:not(:disabled){opacity:.9}.btn-icon:hover{background:var(--card-border);border-radius:8px}}@media (width>=1440px){.app-container{max-width:860px}}@media (width<=430px){.app-container{max-width:100%}}[data-theme=dark] input[type=date]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}:root input[type=date]{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}@media (width>=1024px){.report-project-row:hover{background:var(--primary-muted)}}.login-page{background:var(--bg-app);justify-content:center;align-items:center;min-height:100dvh;padding:1.5rem;display:flex;position:relative;overflow:hidden}.login-blob{filter:blur(80px);opacity:.35;pointer-events:none;border-radius:50%;animation:12s ease-in-out infinite alternate blobDrift;position:absolute}.login-blob-1{background:radial-gradient(circle,#3d7af5,#0000 70%);width:420px;height:420px;animation-duration:10s;top:-120px;left:-80px}.login-blob-2{background:radial-gradient(circle,#7e47eb,#0000 70%);width:320px;height:320px;animation-duration:14s;bottom:-80px;right:-60px}.login-blob-3{background:radial-gradient(circle,#30c9e8,#0000 70%);width:260px;height:260px;animation-duration:18s;top:40%;left:50%}[data-theme=dark] .login-blob{opacity:.25}@keyframes blobDrift{0%{transform:translate(0)scale(1)}50%{transform:translate(30px,-20px)scale(1.05)}to{transform:translate(-20px,25px)scale(.95)}}.login-card{z-index:1;background:var(--card-bg);border:1px solid var(--card-border);-webkit-backdrop-filter:blur(4px);border-radius:20px;width:100%;max-width:380px;padding:2rem 1.75rem;animation:.35s cubic-bezier(.25,1,.5,1) scaleIn;position:relative;box-shadow:0 20px 60px #00000026,0 4px 16px #00000014}[data-theme=dark] .login-card{box-shadow:0 20px 60px #00000080,0 4px 16px #0000004d}.login-logo-wrap{justify-content:center;margin-bottom:1.25rem;display:flex}.login-logo{object-fit:contain;width:auto;height:52px}.login-title{letter-spacing:-.025em;text-align:center;color:var(--text-primary);margin:0 0 .25rem;font-size:1.5rem;font-weight:700}.login-subtitle{text-align:center;color:var(--text-tertiary);margin:0 0 1.75rem;font-size:.875rem}.login-form{flex-direction:column;gap:1rem;display:flex}.login-field{flex-direction:column;gap:.375rem;display:flex}.login-label{color:var(--text-secondary);letter-spacing:.01em;font-size:.8125rem;font-weight:600}.login-input-wrap{align-items:center;display:flex;position:relative}.login-input-icon{color:var(--text-tertiary);pointer-events:none;flex-shrink:0;position:absolute;left:.75rem}.login-input{background:var(--bg-secondary);border:1.5px solid var(--card-border);width:100%;color:var(--text-primary);box-sizing:border-box;border-radius:10px;outline:none;padding:.6875rem .875rem;font-family:inherit;font-size:1rem;transition:border-color .15s,box-shadow .15s;padding-left:2.5rem!important}.login-input--password{padding-right:2.75rem}.login-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #007aff26}.login-input::placeholder{color:var(--text-tertiary);opacity:.7}.login-input:disabled{opacity:.6}.login-show-btn{cursor:pointer;color:var(--text-tertiary);background:0 0;border:none;align-items:center;padding:0;line-height:1;display:flex;position:absolute;right:.75rem}.login-show-btn:hover{color:var(--text-secondary)}.login-error{color:var(--danger);background:#ff3b3014;border:1px solid #ff3b3033;border-radius:8px;align-items:center;gap:.5rem;padding:.625rem .875rem;font-size:.8125rem;display:flex}.login-btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:.5rem;margin-top:.25rem;padding:.8125rem 1.25rem;font-family:inherit;font-size:1rem;font-weight:600;transition:opacity .15s,transform .12s,box-shadow .15s;display:flex;box-shadow:0 4px 16px #007aff59}.login-btn:hover:not(:disabled){opacity:.9;box-shadow:0 6px 20px #007aff73}.login-btn:active:not(:disabled){transform:scale(.98)}.login-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.login-footer{text-align:center;color:var(--text-tertiary);margin:1.25rem 0 0;font-size:.8125rem}.header-user{align-items:center;gap:.375rem;margin-left:.25rem;display:flex}.header-user-name{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;max-width:80px;font-size:.8125rem;font-weight:600;overflow:hidden}@media (width<=767px){.header-user-name{display:none}.header-title{max-width:45%!important}}.header-user-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;display:flex}.header-user-avatar--admin{color:var(--primary);background:#007aff26}.header-user-avatar--user{color:var(--accent);background:#34c75926}.header-user-avatar--viewer{color:var(--text-secondary);background:#8e8e9326}.header-user-avatar--supervisor{color:var(--indigo,#5856d6);background:#5856d626}.header-logout-btn{color:var(--text-tertiary)!important}.header-logout-btn:hover{color:var(--danger)!important}.admin-panel{flex-direction:column;gap:1rem;display:flex}.admin-panel-header{justify-content:space-between;align-items:flex-start;gap:.75rem;display:flex}.admin-panel-title{letter-spacing:-.02em;align-items:center;gap:.5rem;margin:0;font-size:1.25rem;font-weight:700;display:flex}.admin-loading{justify-content:center;padding:3rem 0;display:flex}.user-list{flex-direction:column;gap:.625rem;display:flex}.user-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:14px;transition:box-shadow .15s;overflow:hidden}.user-card--expanded{border-color:var(--primary);box-shadow:0 4px 20px #007aff1f}.user-card-row{align-items:center;gap:.75rem;padding:.875rem 1rem;display:flex}.user-avatar{letter-spacing:-.01em;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:1.0625rem;font-weight:700;display:flex}.user-avatar--admin{color:var(--primary);background:#007aff26}.user-avatar--user{color:var(--accent);background:#34c7591f}.user-avatar--viewer{color:var(--text-secondary);background:#8e8e931f}.user-avatar--supervisor{color:var(--indigo,#5856d6);background:#5856d626}.user-info{flex:1;min-width:0}.user-name{text-overflow:ellipsis;white-space:nowrap;align-items:center;gap:.375rem;font-size:.9375rem;font-weight:600;display:flex;overflow:hidden}.user-meta{color:var(--text-tertiary);flex-wrap:wrap;align-items:center;gap:.3rem;margin-top:.125rem;font-size:.75rem;display:flex}.user-actions{flex-shrink:0;align-items:center;gap:.125rem;display:flex}.user-expand-btn{color:var(--text-tertiary);align-items:center;gap:.125rem;display:flex}.user-expand-btn.active{color:var(--primary)}.you-badge{color:var(--primary);letter-spacing:.03em;background:#007aff1f;border-radius:4px;padding:.125rem .4rem;font-size:.6875rem;font-weight:600}.role-badge{letter-spacing:.04em;text-transform:uppercase;border-radius:20px;align-items:center;gap:.25rem;padding:.125rem .5rem;font-size:.6875rem;font-weight:700;display:inline-flex}.role-badge--admin{color:var(--primary);background:#007aff1f}.role-badge--user{color:var(--accent);background:#34c7591a}.role-badge--viewer{color:var(--text-secondary);background:#8e8e931f}.role-badge--supervisor{color:var(--indigo,#5856d6);background:#5856d626}.user-project-assign{border-top:1px solid var(--separator);padding:.875rem 1rem 1rem}.project-assign-grid{flex-wrap:wrap;gap:.5rem;display:flex}.project-assign-chip{cursor:pointer;border:1.5px solid var(--card-border);background:var(--bg-secondary);color:var(--text-secondary);border-radius:20px;align-items:center;gap:.375rem;padding:.4375rem .75rem;font-family:inherit;font-size:.8125rem;font-weight:500;transition:all .15s;display:inline-flex}.project-assign-chip:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.project-assign-chip.active{border-color:var(--primary);color:var(--primary);background:#007aff1f}.project-assign-chip:disabled{opacity:.6;cursor:not-allowed}.chip-inactive{text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);opacity:.7;font-size:.625rem}.chip-name{text-overflow:ellipsis;white-space:nowrap;max-width:120px;font-weight:600;overflow:hidden}.chip-code{color:var(--text-tertiary);opacity:.8;font-size:.6875rem}.project-assign-wrap{flex-direction:column;gap:.75rem;display:flex}.assign-summary{align-items:center;gap:.5rem;font-size:.8125rem;display:flex}.assign-summary-count{color:var(--primary);background:#007aff1a;border-radius:20px;align-items:center;gap:.3rem;padding:.2rem .6rem;font-weight:700;display:inline-flex}.assign-summary-total{color:var(--text-tertiary)}.assign-search-wrap{align-items:center;display:flex;position:relative}.assign-search-icon{color:var(--text-tertiary);pointer-events:none;flex-shrink:0;position:absolute;left:.625rem}.assign-search-input{border:1.5px solid var(--card-border);width:100%;color:var(--text-primary);box-sizing:border-box;border-radius:10px;outline:none;padding-top:.5rem;padding-bottom:.5rem;padding-right:2.25rem;font-family:inherit;font-size:.875rem;transition:border-color .15s,box-shadow .15s;background:var(--card-bg)!important;padding-left:2rem!important}.assign-search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #007aff1f}.assign-search-input::placeholder{color:var(--text-tertiary);opacity:.7}.assign-search-clear{background:var(--card-border);cursor:pointer;width:18px;height:18px;color:var(--text-tertiary);border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;transition:background .12s;display:flex;position:absolute;right:.625rem}.assign-search-clear:hover{background:var(--separator)}.assign-section{flex-direction:column;gap:.5rem;display:flex}.assign-section-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);align-items:center;gap:.4rem;margin:0;font-size:.6875rem;font-weight:700;display:flex}.assign-section-count{background:var(--card-border);color:var(--text-tertiary);border-radius:20px;padding:.05rem .45rem;font-size:.625rem;font-weight:700}.show-all-btn{cursor:pointer;color:var(--primary);background:0 0;border:none;align-items:center;gap:.25rem;padding:.25rem 0;font-family:inherit;font-size:.8125rem;font-weight:600;transition:opacity .15s;display:inline-flex}.show-all-btn:hover{opacity:.75}.show-all-btn--collapse{color:var(--text-tertiary);font-weight:500}.modal-backdrop{z-index:200;-webkit-backdrop-filter:blur(4px)saturate(180%);backdrop-filter:blur(4px)saturate(180%);background:#00000059;justify-content:center;align-items:center;padding:1rem;animation:.15s fadeIn;display:flex;position:fixed;inset:0}[data-theme=dark] .modal-backdrop{background:#0000008c}.modal-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:16px;width:100%;max-width:420px;animation:.2s cubic-bezier(.25,1,.5,1) scaleIn;overflow:hidden;box-shadow:0 12px 40px #0003}.modal-card--sm{max-width:320px}.modal-header{border-bottom:1px solid var(--separator);justify-content:space-between;align-items:center;padding:1rem 1.25rem .875rem;display:flex}.modal-title{letter-spacing:-.01em;margin:0;font-size:1.0625rem;font-weight:700}.modal-body{flex-direction:column;gap:1rem;max-height:60vh;padding:1.25rem;display:flex;overflow-y:auto}.modal-footer{border-top:1px solid var(--separator);justify-content:flex-end;align-items:center;gap:.625rem;padding:.875rem 1.25rem;display:flex}.form-group{flex-direction:column;gap:.375rem;display:flex}.form-label{color:var(--text-secondary);font-size:.8125rem;font-weight:600}.form-input{background:var(--bg-secondary);border:1.5px solid var(--card-border);width:100%;color:var(--text-primary);box-sizing:border-box;-webkit-appearance:none;border-radius:10px;outline:none;padding:.625rem .875rem;font-family:inherit;font-size:.9375rem;transition:border-color .15s,box-shadow .15s}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #007aff26}.form-input option{background:var(--card-bg)}.btn-danger{background:var(--danger);color:#fff;cursor:pointer;border:none;border-radius:10px;align-items:center;gap:.375rem;padding:.5625rem 1rem;font-family:inherit;font-size:.9375rem;font-weight:600;transition:opacity .15s,transform .12s;display:inline-flex}.btn-danger:hover:not(:disabled){opacity:.88}.btn-danger:active:not(:disabled){transform:scale(.97)}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.btn-icon--danger:hover{color:var(--danger)!important}.share-sheet-backdrop{z-index:300;-webkit-backdrop-filter:blur(8px)saturate(180%);backdrop-filter:blur(8px)saturate(180%);background:#00000073;justify-content:center;align-items:flex-end;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@media (width>=600px){.share-sheet-backdrop{align-items:center;padding:1rem}}.share-sheet{background:var(--card-bg);border:1px solid var(--card-border);border-bottom:none;border-top-left-radius:20px;border-top-right-radius:20px;width:100%;max-width:480px;padding:0 1.25rem 2rem;animation:.3s cubic-bezier(.25,1,.5,1) slideUpSheet;box-shadow:0 -8px 40px #00000040}@media (width>=600px){.share-sheet{border-bottom:1px solid var(--card-border);border-radius:18px;animation:.22s cubic-bezier(.34,1.56,.64,1) popIn}.share-sheet-handle{display:none}}@keyframes slideUpSheet{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes popIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.share-sheet-handle{background:var(--card-border);border-radius:2px;width:40px;height:4px;margin:.75rem auto 0}.share-sheet-header{border-bottom:1px solid var(--separator);justify-content:space-between;align-items:center;margin-bottom:1rem;padding:.875rem 0 .75rem;display:flex}.share-sheet-title{letter-spacing:-.01em;align-items:center;gap:.5rem;margin:0;font-size:1.0625rem;font-weight:700;display:flex}.share-preview-card{background:var(--bg-secondary);border:1px solid var(--card-border);border-radius:12px;align-items:center;gap:.75rem;margin-bottom:.875rem;padding:.75rem;display:flex}.share-preview-thumb{object-fit:cover;border-radius:8px;flex-shrink:0;width:60px;height:60px}.share-preview-info{flex:1;min-width:0}.share-preview-title{text-overflow:ellipsis;white-space:nowrap;margin:0 0 .25rem;font-size:.9375rem;font-weight:700;overflow:hidden}.share-preview-sub{color:var(--text-tertiary);margin:0 0 .125rem;font-size:.8125rem}.share-url-row{background:var(--bg-secondary);border:1px solid var(--card-border);border-radius:8px;align-items:center;gap:.5rem;margin-bottom:1.25rem;padding:.5rem .75rem;display:flex}.share-url-icon{color:var(--primary);flex-shrink:0}.share-url-text{color:var(--text-tertiary);text-overflow:ellipsis;white-space:nowrap;font-family:monospace;font-size:.75rem;overflow:hidden}.share-actions{justify-content:center;gap:2rem;display:flex}.share-action-btn{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;flex-direction:column;align-items:center;gap:.5rem;padding:.25rem;font-family:inherit;font-size:.8125rem;font-weight:600;transition:transform .12s;display:flex}.share-action-btn:hover{transform:translateY(-2px)}.share-action-btn:active{transform:scale(.94)}.share-action-btn span{white-space:nowrap;font-size:.75rem}.share-action-icon{background:var(--bg-secondary);border:1px solid var(--card-border);width:52px;height:52px;color:var(--text-secondary);border-radius:14px;justify-content:center;align-items:center;transition:background .15s,border-color .15s;display:flex}.share-action-icon--success{border-color:var(--accent);color:var(--accent);background:#34c75926}.share-action-icon--whatsapp{color:#fff;background:#25d366;border-color:#25d366}.share-action-icon--line{color:#fff;background:#06c755;border-color:#06c755}.public-report-page{background:var(--bg-app);flex-direction:column;min-height:100dvh;display:flex}.public-report-loading{min-height:60vh;color:var(--text-tertiary);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:.75rem;display:flex}.public-report-header{background:var(--nav-bg);-webkit-backdrop-filter:saturate(180%)blur(4px);border-bottom:.5px solid var(--separator);z-index:50;grid-template-columns:1fr auto 1fr;align-items:center;gap:.625rem;padding:.75rem 1.25rem;display:grid;position:sticky;top:0}.public-report-logo{object-fit:contain;border-radius:6px;width:auto;height:28px}.public-report-header-left{justify-content:flex-start;align-items:center;display:flex}.public-report-header-center{text-align:center;justify-content:center;align-items:center;min-width:0;display:flex}.public-report-header-title{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.9375rem;font-weight:700;overflow:hidden}.public-report-header-right{justify-content:flex-end;align-items:center;gap:.5rem;display:flex}.public-report-badge{text-transform:uppercase;letter-spacing:.05em;color:var(--primary);background:#007aff1f;border-radius:20px;padding:.2rem .6rem;font-size:.6875rem;font-weight:700}.public-lang-switcher{background:#7878801f;border-radius:9px;align-items:center;gap:1px;padding:2px;display:flex}.public-lang-btn{color:var(--text-secondary);cursor:pointer;white-space:nowrap;letter-spacing:-.01em;background:0 0;border:none;border-radius:7px;padding:.25rem .6rem;font-size:.75rem;font-weight:600;line-height:1.4;transition:background .2s,color .2s,box-shadow .2s}.public-lang-btn:hover{color:var(--text-primary)}.public-lang-btn.active{background:var(--card-bg,#fff);color:var(--text-primary);box-shadow:0 1px 4px #00000024,0 .5px 1px #00000014}[data-theme=dark] .public-lang-btn.active{background:#ffffff1f;box-shadow:0 1px 4px #00000080}.public-report-body{flex-direction:column;gap:1rem;width:100%;max-width:640px;margin:0 auto;padding:1.25rem 1rem 3rem;display:flex}.public-report-hero{aspect-ratio:16/8;background:var(--card-border);border-radius:14px;position:relative;overflow:hidden}.public-report-hero-img{object-fit:cover;cursor:zoom-in;width:100%;height:100%}.public-report-hero-more{color:#ffffffe6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0000008c;border-radius:20px;padding:.25rem .625rem;font-size:.75rem;font-weight:600;position:absolute;bottom:.75rem;right:.75rem}.public-report-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:14px;padding:1.25rem 1rem}.public-report-title{letter-spacing:-.025em;margin:0 0 .875rem;font-size:1.375rem;font-weight:800;line-height:1.25}.public-report-progress-row{align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.public-report-progress-bar{background:var(--card-border);border-radius:4px;flex:1;height:6px;overflow:hidden}.public-report-progress-fill{background:var(--accent);border-radius:4px;height:100%;transition:width .5s cubic-bezier(.25,1,.5,1)}.public-report-progress-label{color:var(--accent);white-space:nowrap;font-size:.8125rem;font-weight:600}.public-report-meta-grid{border-top:1px solid var(--separator);grid-template-columns:repeat(2,1fr);gap:.75rem;padding:.875rem 0 0;display:grid}.pub-meta-item{align-items:flex-start;gap:.5rem;display:flex}.pub-meta-icon{color:var(--primary);flex-shrink:0;margin-top:1px}.pub-meta-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);margin-bottom:.125rem;font-size:.6875rem;font-weight:700}.pub-meta-value{color:var(--text-primary);font-size:.875rem;font-weight:600}.public-report-overall-comment{border-top:1px solid var(--separator);margin-top:.75rem;padding:.875rem 0 0}.public-report-comment-text{color:var(--text-secondary);background:var(--primary-muted);border-radius:8px;margin-top:.375rem;padding:.625rem .75rem;font-size:.9375rem;line-height:1.5}.public-report-section-label{letter-spacing:.07em;color:var(--text-tertiary);margin:0;padding:0 .25rem;font-size:.6875rem;font-weight:700}.public-report-items{flex-direction:column;gap:.5rem;display:flex}.public-report-item{background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;align-items:flex-start;gap:.75rem;padding:.875rem 1rem;display:flex}.public-report-item.completed{border-left:3px solid var(--accent)}.public-report-item.incomplete{opacity:.75}.public-item-check{border:2px solid var(--text-quaternary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;margin-top:1px;display:flex}.public-item-check.checked{background:var(--accent);border-color:var(--accent)}.public-item-body{flex:1;min-width:0}.public-item-text{color:var(--text-primary);margin:0 0 .375rem;font-size:.9375rem;line-height:1.4}.public-item-comment{color:var(--text-secondary);background:var(--primary-muted);border-radius:8px;margin-top:.5rem;padding:.5rem .75rem;font-size:.8125rem;line-height:1.4}.public-item-photos{margin-top:.75rem}.public-item-photo-grid{flex-wrap:wrap;gap:.375rem;margin-top:.375rem;display:flex}.public-item-photo{object-fit:cover;cursor:zoom-in;border-radius:8px;width:72px;height:72px;transition:opacity .12s}.public-item-photo:hover{opacity:.88}.public-report-footer{color:var(--text-tertiary);text-align:center;justify-content:center;align-items:center;gap:.375rem;padding:1rem 0 .5rem;font-size:.75rem;line-height:1.5;display:flex}.pub-lightbox{z-index:500;cursor:zoom-out;background:#000000e6;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.pub-lightbox-img{object-fit:contain;border-radius:6px;max-width:92vw;max-height:88vh;animation:.2s cubic-bezier(.25,1,.5,1) scaleIn}.pub-lightbox-close{color:#fff;cursor:pointer;background:#ffffff26;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:1rem;transition:background .15s;display:flex;position:absolute;top:1rem;right:1rem}.pub-lightbox-close:hover{background:#ffffff4d}@media (width>=640px){.public-report-meta-grid{grid-template-columns:repeat(4,1fr)}.public-item-photo{width:90px;height:90px}}.esign-overlay{z-index:400;-webkit-backdrop-filter:blur(8px)saturate(180%);backdrop-filter:blur(8px)saturate(180%);background:#00000073;justify-content:center;align-items:flex-end;padding:0;animation:.18s fadeIn;display:flex;position:fixed;inset:0}@media (width>=600px){.esign-overlay{align-items:center;padding:1rem}}.esign-modal{background:var(--card-bg);border-radius:20px 20px 0 0;flex-direction:column;width:100%;max-width:640px;animation:.26s cubic-bezier(.32,.72,0,1) slideUp;display:flex;overflow:hidden}@media (width>=600px){.esign-modal{border-radius:18px}}.esign-header{border-bottom:.5px solid var(--separator);justify-content:space-between;align-items:center;padding:1rem 1.25rem .75rem;display:flex}.esign-header-left{align-items:center;gap:.5rem;display:flex}.esign-title{color:var(--text-primary);letter-spacing:-.01em;font-size:1rem;font-weight:700}.esign-close{color:var(--text-tertiary)}.esign-role-row{flex-wrap:wrap;align-items:center;gap:.75rem;padding:.75rem 1.25rem 0;display:flex}.esign-role-label{color:var(--text-tertiary);white-space:nowrap;font-size:.8125rem;font-weight:500}.esign-segment{flex:1;min-width:220px}.esign-name-row{flex-direction:column;gap:.375rem;padding:.75rem 1.25rem 0;display:flex}.esign-name-label{color:var(--text-secondary);font-size:.8125rem;font-weight:600}.esign-name-input{width:100%}.esign-canvas-section{flex-direction:column;padding:.75rem 1.25rem 0;display:flex}.esign-canvas-hint{color:var(--text-tertiary);margin-bottom:.5rem;font-size:.75rem;font-weight:500}.esign-canvas-wrap{border:1.5px solid var(--separator);cursor:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round'><line x1='12' y1='4' x2='12' y2='20'/><line x1='4' y1='12' x2='20' y2='12'/></svg>") 12 12,crosshair;touch-action:none;background:#fff;border-radius:12px;height:200px;position:relative;overflow:hidden}.esign-canvas{touch-action:none;width:100%;height:100%;display:block}.esign-canvas-placeholder{color:var(--text-tertiary);pointer-events:none;-webkit-user-select:none;user-select:none;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;font-size:.8125rem;display:flex;position:absolute;inset:0}.esign-actions{border-top:.5px solid var(--separator);padding:.875rem 1.25rem;padding-bottom:max(.875rem, env(safe-area-inset-bottom,.875rem));justify-content:space-between;align-items:center;gap:.5rem;display:flex}.esign-actions-right{gap:.5rem;display:flex}.esign-btn-clear{color:var(--text-tertiary)}.sig-blocks-row{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}.sig-block{border-radius:14px;flex-direction:column;gap:.375rem;min-height:130px;padding:1rem;display:flex}.sig-block--signed{background:var(--card-bg);border:1px solid var(--separator)}.sig-block--empty{background:var(--bg-secondary);border:1px dashed var(--separator)}.sig-block-role{text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);margin:0;font-size:.7rem;font-weight:700}.sig-block-img{object-fit:contain;background:#fff;border-radius:6px;width:100%;height:70px;padding:2px}.sig-block-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:.8rem;font-weight:600;overflow:hidden}.sig-block-date{color:var(--text-tertiary);align-items:center;gap:3px;margin:0;font-size:.7rem;display:flex}.sig-block-placeholder{color:var(--text-tertiary);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:.375rem;font-size:.75rem;display:flex}.sign-options-body{padding:.5rem 0 max(.75rem, env(safe-area-inset-bottom,.75rem));overflow-y:auto}.sign-option-group{flex-direction:column;gap:.5rem;padding:.75rem 1.25rem;display:flex}.sign-option-group-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);margin:0 0 .25rem;font-size:.7rem;font-weight:700}.sign-option-btn{background:var(--bg-secondary);border:1px solid var(--separator);cursor:pointer;text-align:left;border-radius:12px;align-items:center;gap:.875rem;width:100%;padding:.875rem 1rem;transition:background .15s;display:flex}.sign-option-btn:hover:not(:disabled){background:var(--bg-tertiary)}.sign-option-btn:disabled{opacity:.6;cursor:not-allowed}.sign-option-btn--link{border-color:#0ea5e94d}.sign-option-text{color:var(--text-primary);flex-direction:column;gap:.125rem;font-size:.9rem;font-weight:600;display:flex}.sign-option-hint{color:var(--text-tertiary);font-size:.75rem;font-weight:400}.sign-option-divider{background:var(--separator);height:.5px;margin:0 1.25rem}.sign-option-signed{background:#34c75914;border:1px solid #34c75940;border-radius:12px;align-items:center;gap:.75rem;padding:.75rem 1rem;display:flex}.sign-option-thumb{object-fit:contain;background:#fff;border-radius:6px;flex-shrink:0;width:52px;height:36px}.sign-option-name{color:var(--text-primary);margin:0;font-size:.875rem;font-weight:600}.sign-option-date{color:var(--text-tertiary);margin:0;font-size:.75rem}.esign-page{max-width:720px;margin:0 auto;padding:1.25rem 1.25rem 6rem}.esign-page-header{border-bottom:.5px solid var(--separator);grid-template-columns:1fr auto 1fr;align-items:center;gap:1rem;margin-bottom:1.25rem;padding-bottom:1.25rem;display:grid}.esign-page-header-left{justify-content:flex-start;align-items:center;display:flex}.esign-page-header-center{text-align:center;justify-content:center;align-items:center;min-width:0;display:flex}.esign-page-header-right{justify-content:flex-end;align-items:center;display:flex}.esign-page-logo{object-fit:contain;width:auto;height:36px}.esign-page-header-info{flex-direction:column;gap:.25rem;display:flex}.esign-page-tag{text-transform:uppercase;letter-spacing:.08em;color:#8b5cf6;background:#8b5cf61a;border-radius:6px;padding:.2rem .5rem;font-size:.7rem;font-weight:700;display:inline-block}.esign-page-title{color:var(--text-primary);letter-spacing:-.01em;margin:0;font-size:1.125rem;font-weight:700;line-height:1.3}.esign-meta-card{background:var(--card-bg);border:1px solid var(--separator);border-radius:14px;margin-bottom:1rem;padding:1rem}.esign-meta-row{color:var(--text-secondary);align-items:center;gap:.5rem;padding:.25rem 0;font-size:.875rem;display:flex}.esign-meta-row svg{color:var(--text-tertiary);flex-shrink:0}.esign-section-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);margin:0 0 .5rem;font-size:.7rem;font-weight:700}.esign-overall-comment{background:var(--card-bg);border-left:3px solid var(--primary);border-radius:14px;margin-bottom:.5rem;padding:1rem}.esign-overall-text{color:var(--text-secondary);margin:0;font-size:.9rem;line-height:1.6}.esign-category-block{border:1px solid var(--separator);background:var(--card-bg);border-radius:14px;margin-bottom:.75rem;overflow:hidden}.esign-cat-header{color:var(--text-primary);background:var(--bg-secondary);cursor:pointer;text-align:left;border:none;justify-content:space-between;align-items:center;width:100%;padding:.875rem 1rem;font-size:.875rem;font-weight:700;display:flex}.esign-cat-items{flex-direction:column;display:flex}.esign-item-row{justify-content:space-between;align-items:flex-start;gap:.75rem;padding:.75rem 1rem;display:flex}.esign-item-info{flex-direction:column;flex:1;gap:.2rem;min-width:0;display:flex}.esign-item-title{color:var(--text-primary);font-size:.875rem;font-weight:600}.esign-item-desc{color:var(--text-tertiary);font-size:.8rem;font-style:italic}.esign-item-comment{color:var(--text-secondary);background:var(--bg-secondary);border-radius:6px;margin-top:.25rem;padding:.25rem .5rem;font-size:.8rem;display:inline-block}.esign-status-badge{white-space:nowrap;text-transform:uppercase;letter-spacing:.04em;border-radius:6px;flex-shrink:0;padding:.25rem .5rem;font-size:.65rem;font-weight:700}.badge-ok{color:#22c55e;background:#34c7591f;border:1px solid #34c7594d}.badge-note{color:#f59e0b;background:#ff95001f;border:1px solid #ff95004d}.badge-notok{color:#ef4444;background:#ff3b301f;border:1px solid #ff3b304d}.badge-null{color:#9ca3af;background:#8e8e931f;border:1px solid #8e8e934d}.esign-success-banner{background:#34c7591a;border:1px solid #34c7594d;border-radius:14px;align-items:flex-start;gap:.875rem;margin-top:1.5rem;padding:1rem 1.25rem;display:flex}.esign-success-title{color:var(--text-primary);margin:0 0 .25rem;font-size:.9375rem;font-weight:700}.esign-success-sub{color:var(--text-secondary);margin:0;font-size:.8125rem;line-height:1.5}.esign-action-bar{z-index:80;background:var(--nav-bg);-webkit-backdrop-filter:saturate(180%)blur(10px);border-top:.5px solid var(--separator);padding:.875rem 1.25rem;padding-bottom:max(.875rem, env(safe-area-inset-bottom,.875rem));position:fixed;bottom:0;left:0;right:0}.esign-action-bar-inner{justify-content:space-between;align-items:center;gap:1rem;max-width:720px;margin:0 auto;display:flex}.esign-action-bar-label{color:var(--text-primary);margin:0 0 .125rem;font-size:.875rem;font-weight:700}.esign-action-bar-sub{color:var(--text-tertiary);margin:0;font-size:.75rem}.esign-sign-btn{white-space:nowrap;color:#fff;background:linear-gradient(135deg,#7c3aed,#8b5cf6);border:none;flex-shrink:0;padding:.625rem 1.25rem;box-shadow:0 4px 14px #8b5cf659}.esign-sign-btn:hover{background:linear-gradient(135deg,#6d28d9,#7c3aed)}.report-actions-container{grid-template-columns:repeat(2,1fr);gap:.75rem;width:100%;margin-top:1.25rem;margin-bottom:.5rem;display:grid}.report-actions-container .btn{box-sizing:border-box;border-radius:10px;justify-content:center;align-items:center;gap:.375rem;width:100%;height:44px;padding:.6875rem 1rem;font-size:.875rem;font-weight:600;transition:background .15s,opacity .15s;display:inline-flex}.report-actions-container .btn-sign-action{order:1;grid-column:span 2}.report-actions-container .btn-pdf-action{order:2;grid-column:span 2}.report-actions-container .btn-edit-action{order:3;grid-column:span 1}.report-actions-container .btn-share-action{order:4;grid-column:span 2}:is(.report-actions-container:has(.btn-edit-action) .btn-share-action,.report-actions-container:has(.btn-edit-action) .btn-edit-action){grid-column:span 1}.report-actions-container .btn-delete-action{order:5;grid-column:span 2;margin-top:.375rem}@media (width>=600px){.report-actions-container{flex-wrap:wrap;justify-content:center;gap:.5rem;display:flex}.report-actions-container .btn{border-radius:8px;width:auto;height:36px;padding:.5rem 1rem;font-size:.8125rem;order:initial!important}.report-actions-container .btn-delete-action{margin-top:0}}.esign-footer-branding{text-align:center;flex-direction:column;align-items:center;gap:.5rem;width:100%;margin-top:2.5rem;margin-bottom:2rem;display:flex}.esign-footer-logo{opacity:.85;width:auto;height:38px;transition:opacity .2s}.esign-footer-logo:hover{opacity:1}.esign-footer-title{color:var(--text-secondary);letter-spacing:.025em;margin:0;font-size:.875rem;font-weight:600}.esign-footer-socials{gap:1.25rem;margin-top:.625rem;display:flex}.esign-social-link{background:var(--primary-muted);width:38px;height:38px;color:var(--primary);box-shadow:var(--shadow-sm);border-radius:50%;justify-content:center;align-items:center;transition:all .2s cubic-bezier(.4,0,.2,1);display:inline-flex}.esign-social-link:active{transform:scale(.92)}.esign-social-link.instagram:hover{color:#db2777;background:#fdf2f8;transform:translateY(-2px)}.esign-social-link.linkedin:hover{color:#0284c7;background:#f0f9ff;transform:translateY(-2px)}.input-char-counter{text-align:right;color:var(--text-tertiary);margin-top:.25rem;font-size:.75rem;font-weight:500;transition:color .15s;display:block}.input-char-counter.warning{color:var(--orange);font-weight:600}.input-char-counter.error{color:var(--danger);font-weight:700}.comments-section{border-top:1px solid var(--separator);flex-direction:column;gap:1rem;margin-top:2rem;padding-top:1rem;display:flex}.comment-bubble{background:var(--card-bg);border:1px solid var(--card-border);box-shadow:var(--shadow-sm);z-index:2;border-radius:12px;flex-direction:column;gap:.5rem;padding:.75rem 1rem;display:flex;position:relative}.comment-header{color:var(--text-tertiary);justify-content:space-between;align-items:center;font-size:.75rem;display:flex}.comment-header-name{color:var(--text-primary);font-size:.8125rem;font-weight:600}.comment-wrapper{flex-direction:column;gap:0;display:flex;position:relative}.comment-reply-container{z-index:1;background:#0a84ff0f;border:1px solid #0a84ff26;border-bottom:none;border-radius:12px 12px 0 0;flex-direction:column;gap:.25rem;margin-bottom:-10px;margin-left:0;margin-right:0;padding:.6rem 1rem .9rem;display:flex;position:relative}.comment-reply-label{color:var(--primary);text-transform:uppercase;letter-spacing:.05em;font-size:.6875rem;font-weight:700}.comment-reply-item{color:var(--text-secondary);box-sizing:border-box;align-items:center;gap:.5rem;font-size:.78125rem;display:flex}.comment-reply-title{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.comment-reply-photo{object-fit:cover;border-radius:4px;flex-shrink:0;width:24px;height:24px;margin-left:.25rem}.comment-text{color:var(--text-primary);word-break:break-word;font-size:.875rem;line-height:1.4}.comment-delete{color:var(--danger);opacity:.6;cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:0;transition:opacity .2s;display:flex}.comment-delete:hover{opacity:1}.comment-input-area{background:var(--card-bg);border:1px solid var(--card-border);box-shadow:var(--shadow-sm);border-radius:12px;flex-direction:column;gap:.5rem;margin-top:1.5rem;margin-bottom:.5rem;padding:.75rem;transition:background-color .2s,box-shadow .2s;display:flex;position:relative}.comment-input-area.is-floating{z-index:90;background:var(--nav-bg);-webkit-backdrop-filter:saturate(180%)blur(12px);bottom:calc(env(safe-area-inset-bottom,0px) + 12px);border:1px solid var(--card-border);border-radius:12px;gap:.375rem;width:calc(100% - 24px);max-width:406px;margin:0;padding:.5rem .625rem;position:fixed;top:auto;left:50%;overflow:hidden;transform:translate(-50%);box-shadow:0 -4px 16px #0000001f,0 -1px #0000000f}.comment-input-quote{color:var(--text-secondary);background:#0a84ff0f;border-bottom:1px solid #0a84ff26;border-top-left-radius:11px;border-top-right-radius:11px;justify-content:space-between;align-items:center;margin:-.5rem -.625rem .5rem;padding:.6rem .75rem;font-size:.8125rem;display:flex}.comment-input-quote-close{color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;display:flex}.comment-input-row{align-items:center;gap:.5rem;display:flex}.comment-input{border:1px solid var(--card-border);resize:none;background:var(--bg-app);color:var(--text-primary);box-sizing:border-box;border-radius:8px;flex:1;height:38px;padding:.625rem;font-family:inherit;font-size:.875rem;overflow-y:hidden;min-height:38px!important}.comment-submit{background:var(--primary);color:#fff;cursor:pointer;box-sizing:border-box;border:none;border-radius:8px;justify-content:center;align-items:center;gap:.25rem;padding:0 1rem;font-weight:600;display:flex;height:38px!important;min-height:38px!important;max-height:38px!important}.comment-submit:disabled{opacity:.5;cursor:not-allowed}.item-reply-btn{background:var(--primary-muted);color:var(--primary);cursor:pointer;-webkit-user-select:none;user-select:none;border:none;border-radius:6px;align-items:center;gap:.375rem;padding:.3rem .6rem;font-size:.75rem;font-weight:600;transition:background .15s,opacity .15s;display:inline-flex}.item-reply-btn:hover{background:color-mix(in srgb, var(--primary) 20%, transparent)}.item-reply-btn:active{opacity:.7}.item-reply-btn--disabled{opacity:.35;cursor:not-allowed}.item-reply-btn--disabled:hover{background:var(--primary-muted)!important}.item-reply-btn--disabled:active{opacity:.35!important}.comment-readonly-notice{color:var(--orange);background:#ff950012;border:1px solid #ff950038;border-radius:10px;align-items:center;gap:.5rem;margin-top:1.5rem;margin-bottom:.5rem;padding:.75rem 1rem;font-size:.8125rem;display:flex}.ios-toast{-webkit-backdrop-filter:blur(16px)saturate(180%);backdrop-filter:blur(16px)saturate(180%);color:#fff;z-index:500;pointer-events:none;white-space:nowrap;background:#1e1e20d1;border-radius:20px;padding:.5rem 1.125rem;font-family:inherit;font-size:.8125rem;font-weight:500;animation:.22s cubic-bezier(.34,1.56,.64,1) forwards ios-toast-in,.3s 2.2s forwards ios-toast-out;position:fixed;bottom:100px;left:50%;transform:translate(-50%);box-shadow:0 4px 20px #00000047}@keyframes ios-toast-in{0%{opacity:0;transform:translate(-50%)scale(.88)}to{opacity:1;transform:translate(-50%)scale(1)}}@keyframes ios-toast-out{0%{opacity:1;transform:translate(-50%)scale(1)}to{opacity:0;transform:translate(-50%)scale(.92)}}.prev-comments-block{margin-top:.75rem}.prev-comments-toggle{color:#b25e00;cursor:pointer;background:#ffcc0026;border:none;border-radius:10px;justify-content:center;align-items:center;gap:.375rem;width:100%;padding:.5rem .875rem;font-family:inherit;font-size:.875rem;font-weight:600;transition:background .15s,transform .15s,opacity .15s;display:flex}.prev-comments-toggle:hover{background:#ffcc0040}.prev-comments-toggle:active{opacity:.85;transform:scale(.97)}[data-theme=dark] .prev-comments-toggle{color:#ffd60a;background:#ffd60a26}[data-theme=dark] .prev-comments-toggle:hover{background:#ffd60a40}.prev-comments-list{flex-direction:column;gap:.5rem;margin-top:.5rem;display:flex}.prev-comments-section-title{letter-spacing:.05em;text-transform:uppercase;color:var(--text-tertiary);margin:0 0 .25rem;font-size:.6875rem;font-weight:700}.prev-comment-item{background:var(--bg-tertiary);border:1px solid var(--card-border);border-radius:8px;padding:.5rem .75rem}.prev-comment-meta{flex-wrap:wrap;align-items:center;gap:.4rem;margin-bottom:.25rem;display:flex}.prev-comment-name{color:var(--text-primary);font-size:.78125rem;font-weight:600}.prev-comment-time{color:var(--text-tertiary);flex:1;font-size:.6875rem}.prev-comment-version-badge{background:var(--primary-muted);color:var(--primary);letter-spacing:.04em;border-radius:99px;padding:.1rem .35rem;font-size:.625rem;font-weight:700}.prev-comment-text{color:var(--text-secondary);word-break:break-word;margin:0;font-size:.8125rem;font-style:italic;line-height:1.45}.prev-comments-show-more{color:var(--primary);cursor:pointer;text-align:left;background:0 0;border:none;padding:.25rem 0;font-family:inherit;font-size:.8125rem;font-weight:600}.prev-comments-card{background:#ffcc001f;border:1px solid #ffcc004d;border-radius:10px;flex-direction:column;gap:.5rem;padding:1rem;display:flex}[data-theme=dark] .prev-comments-card{background:#ffd60a1f;border:1px solid #ffd60a4d}.share-message-preview-container{margin-bottom:.875rem}.share-message-preview{background:var(--bg-secondary);border:1px solid var(--card-border);color:var(--text-primary);white-space:pre-wrap;text-align:left;border-radius:12px;max-height:140px;margin:0;padding:.75rem 1rem;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.8125rem;line-height:1.4;overflow-y:auto}
