:root{--text:#596173;--text-h:#111827;--bg:#f7f8fb;--border:#d9dee8;--panel-bg:#fff;--input-bg:#fff;--accent:#1f5eff;--error:#9f1239;--error-bg:#ffe4e6;--shadow:0 16px 40px #0f172a14;--sans:system-ui, "Segoe UI", Roboto, sans-serif;font:16px/145% var(--sans);color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--text:#a7b0c0;--text-h:#f8fafc;--bg:#10131a;--border:#293241;--panel-bg:#161b24;--input-bg:#10131a;--accent:#5b8cff;--error:#fecdd3;--error-bg:#4c0519;--shadow:0 16px 40px #00000047}}body{margin:0}a{color:inherit}h1,h2,p{margin-top:0}:root{--tecfesa-blue:#0060a8;--tecfesa-blue-dark:#073f70;--tecfesa-blue-soft:#e9f5ff;--tecfesa-green:#13a66b;--tecfesa-green-dark:#087247;--ink:#0f172a;--muted:#667085;--soft:#f4f8fb;--surface:#ffffffbd;--surface-strong:#fff;--line:#10182814;--shadow:0 26px 70px #00488024;--shadow-soft:0 14px 36px #0f172a14}*{box-sizing:border-box}html{background:#f5f9fc}.auth-page,.app-shell{min-height:100svh}.auth-page{place-items:center;padding:24px;display:grid}.auth-card,.panel,.home-screen,.flow-screen,.capture-screen{width:min(100%,960px);margin:0 auto}.auth-card,.panel,.flow-card,.camera-card,.photo-card,.internal-notes-card,.quiet-meta-card,.capture-title-card,.done-card,.hero-panel,.home-hero-card{background:var(--surface);box-shadow:var(--shadow-soft);-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px);border:1px solid #ffffffb8}.auth-card,.panel{border-radius:28px;padding:24px}.auth-card{text-align:left;max-width:460px}.app-shell{padding:18px 14px calc(104px + env(safe-area-inset-bottom));text-align:left;background:radial-gradient(circle at 18% -8%,#0060a82e,#0000 30rem),radial-gradient(circle at 108% 18%,#13a66b29,#0000 25rem),linear-gradient(#f7fbff 0%,#eef8f5 46%,#f7f9fc 100%);position:relative;overflow-x:hidden}.app-shell:before{content:"";pointer-events:none;background:linear-gradient(135deg,#ffffff6b,#0000 42%),radial-gradient(circle at 35% 8%,#ffffffd6,#0000 15rem);position:fixed;inset:0}.mobile-topbar{z-index:30;justify-content:space-between;align-items:center;max-width:960px;margin:0 auto 18px;display:flex;position:relative}.mini-brand,.brand-mark{color:var(--ink);letter-spacing:-.02em;align-items:center;gap:10px;font-weight:850;text-decoration:none;display:inline-flex}.mini-brand{background:#ffffff8a;border:1px solid #ffffffa8;border-radius:18px;min-height:48px;padding:9px 12px;box-shadow:0 10px 26px #00488012}.brand-logo{object-fit:contain;height:auto;display:block}.brand-logo.small{max-width:132px;max-height:28px}.brand-logo.home{max-width:min(250px,72vw);max-height:58px}.brand-mark{background:#ffffffc7;border:1px solid #0060a81a;border-radius:22px;padding:12px 16px;box-shadow:0 14px 38px #0060a81a}.brand-symbol,.brand-symbol.small{display:none}.hamburger-menu{position:relative}.hamburger-menu summary{cursor:pointer;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#ffffff6b;border:1px solid #ffffffa3;border-radius:16px;justify-content:center;align-items:center;gap:6px;width:44px;height:44px;list-style:none;display:grid;box-shadow:0 10px 24px #00488014}.hamburger-menu summary::-webkit-details-marker{display:none}.hamburger-menu summary span{background:#126f88;border-radius:999px;width:18px;height:1.5px;display:block}.hamburger-menu[open] summary span:first-child{transform:translateY(3.75px)rotate(45deg)}.hamburger-menu[open] summary span:last-child{transform:translateY(-3.75px)rotate(-45deg)}.hamburger-menu nav{z-index:40;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff0;border:1px solid #ffffffe6;border-radius:24px;gap:6px;min-width:236px;padding:10px;display:grid;position:absolute;top:56px;right:0;box-shadow:0 24px 70px #0f172a2e}.hamburger-menu a,.hamburger-menu button{box-shadow:none;color:var(--ink);font:inherit;text-align:left;background:0 0;border:0;border-radius:16px;justify-content:flex-start;align-items:center;min-height:46px;padding:12px 14px;font-weight:760;text-decoration:none;display:flex}.hamburger-menu a:hover,.hamburger-menu button:hover{background:#eef7fb}.eyebrow{color:var(--tecfesa-blue);letter-spacing:.14em;text-transform:uppercase;margin:0 0 10px;font-size:11px;font-weight:860}h1,h2{color:var(--ink);letter-spacing:-.058em;margin:0 0 12px;line-height:1.02}h1{font-size:clamp(34px,8.7vw,64px)}h2{font-size:clamp(25px,6vw,38px)}p,.muted,.hint-text{color:var(--muted)}.home-screen{text-align:center;z-index:1;place-items:center;min-height:calc(100svh - 124px);padding:4px 0 24px;display:grid;position:relative}.home-ambient{filter:blur(18px);pointer-events:none;background:radial-gradient(circle at 26% 24%,#0060a82e,#0000 18rem),radial-gradient(circle at 78% 38%,#13a66b2e,#0000 16rem);height:68%;position:absolute;inset:0 -20px auto}.home-hero-card{background:linear-gradient(165deg,#ffffffd1 0%,#ffffff9e 50%,#eef9f794 100%);border-radius:40px;gap:22px;width:100%;padding:clamp(30px,7vw,58px) clamp(18px,5vw,44px) 24px;display:grid;position:relative;overflow:hidden}.home-hero-card:before{content:"";pointer-events:none;background:linear-gradient(#ffffffd1,#0000 72%);border-radius:999px;width:220px;height:220px;position:absolute;top:-118px;right:-82px}.home-hero-card:after{content:"";opacity:.8;background:linear-gradient(90deg,#0060a83d,#13a66b38);border-radius:999px;height:4px;position:absolute;top:0;left:34%;right:34%}.home-copy-block,.home-copy{z-index:1;max-width:680px;margin:0 auto;position:relative}.home-lead,.home-copy p:last-child,.home-hint{color:#667085;max-width:560px;margin:0 auto;font-size:clamp(17px,4.2vw,22px);line-height:1.42}.primary-cta,.sticky-submit,.button-link,button{background:linear-gradient(135deg, var(--tecfesa-blue), var(--tecfesa-green));color:#fff;cursor:pointer;font:inherit;border:0;border-radius:22px;justify-content:center;align-items:center;min-height:54px;padding:14px 20px;font-weight:850;text-decoration:none;display:inline-flex}.primary-cta{z-index:1;background:radial-gradient(circle at 20% 0,#ffffff42,#0000 34%),linear-gradient(135deg,#005f9f 0%,#0780a7 45%,#13a66b 100%);justify-content:flex-start;gap:14px;width:min(100%,560px);min-height:124px;margin:8px auto 0;padding:22px;position:relative;overflow:hidden;box-shadow:0 28px 60px #0060a847,inset 0 1px #ffffff47}.primary-cta:after{content:"";background:linear-gradient(90deg,#0000,#ffffff42,#0000);width:34%;height:100%;position:absolute;top:0;right:-38%;transform:skew(-16deg)}.cta-icon-shell{background:#ffffff26;border:1px solid #ffffff38;border-radius:22px;justify-content:center;align-items:center;width:58px;height:58px;display:inline-flex}.cta-copy{text-align:left;gap:5px;display:grid}.cta-copy strong{letter-spacing:-.02em;font-size:clamp(22px,5.6vw,31px);line-height:1}.cta-copy small{color:#ffffffc7;font-size:13px;font-weight:740}.cta-svg-icon,.source-icon{flex:none;width:34px;height:34px}.home-flow,.mini-steps{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.home-flow{z-index:1;grid-template-columns:repeat(3,1fr);margin-top:2px;display:grid;position:relative}.home-flow-step,.mini-steps span{color:#315069;background:#ffffff9e;border:1px solid #0060a814;border-radius:20px;padding:10px;font-size:13px;font-weight:800}.home-flow-step{place-items:center;gap:7px;min-height:86px;display:grid}.home-flow-step svg{color:var(--tecfesa-blue);width:23px;height:23px}.home-flow-step span{gap:2px;display:grid}.home-flow-step strong,.home-flow-step small{display:block}.home-flow-step small{color:#6b7d8f;font-size:11px;font-weight:720}button:disabled,.sticky-submit:disabled,.type-card:disabled{cursor:not-allowed;opacity:.52}.back-link{color:#40617d;z-index:1;margin-bottom:2px;font-weight:800;text-decoration:none;display:inline-flex;position:relative}.flow-screen,.capture-screen{z-index:1;gap:16px;display:grid;position:relative}.flow-heading{padding:4px 4px 8px}.hero-panel{border-radius:30px;padding:22px}.simple-flow,.login-form,.entity-form,.capture-form,.dynamic-form,.form-section{gap:16px;display:grid}.flow-card,.camera-card,.add-more-card,.work-summary-card,.internal-notes-card,.quiet-meta-card,.capture-title-card,.done-card{border-radius:30px;padding:20px}.step-label{color:var(--tecfesa-blue);text-transform:uppercase;margin-bottom:14px;font-size:13px;font-weight:850}.type-grid{grid-template-columns:repeat(auto-fit,minmax(142px,1fr));gap:12px;display:grid}.type-card{box-shadow:none;color:var(--ink);text-align:left;background:#ffffffb8;border:1px solid #0060a814;border-radius:24px;justify-content:stretch;align-items:flex-start;gap:9px;min-height:102px;padding:18px;font-size:17px;display:grid;position:relative}.type-card:before{background:linear-gradient(135deg, var(--tecfesa-blue), var(--tecfesa-green));content:"";border-radius:999px;width:34px;height:9px}.type-card small{color:#667085;font-size:12px;font-weight:750}.type-card.selected{background:linear-gradient(135deg, var(--tecfesa-blue), var(--tecfesa-green));color:#fff;transform:translateY(-1px);box-shadow:0 18px 40px #0060a838}.type-card.selected:before{background:#ffffffa6}.type-card.selected small{color:#ffffffd1}.disabled-section{opacity:.68}.client-toggle{background:#eef6fae0;border-radius:20px;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:16px;padding:5px;display:grid}.client-toggle button{box-shadow:none;color:#344054;background:0 0;min-height:46px;padding:10px}.client-toggle button.selected{color:var(--tecfesa-blue);background:#fff;box-shadow:0 10px 26px #0048801a}.basic-grid,.capture-meta-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;display:grid}label,.photo-card label{color:#182230;gap:8px;font-size:14px;font-weight:800;display:grid}select,input,textarea{box-sizing:border-box;color:var(--ink);font:inherit;background:#ffffffeb;border:1px solid #0060a81f;border-radius:18px;width:100%;min-height:54px;padding:14px 15px}select:focus,input:focus,textarea:focus{border-color:#0060a873;outline:none;box-shadow:0 0 0 4px #0060a81a}textarea{resize:vertical;min-height:134px;line-height:1.45}.sticky-submit{bottom:calc(14px + env(safe-area-inset-bottom));letter-spacing:.03em;z-index:10;min-height:66px;position:sticky;box-shadow:0 22px 50px #0060a83d}.capture-title-card{background:radial-gradient(circle at 92% 0,#13a66b2e,#0000 9rem),linear-gradient(145deg,#ffffffd6,#f1f9ffb3);grid-template-columns:1fr auto;align-items:end;gap:18px;display:grid;position:relative;overflow:hidden}.capture-title-card:before{background:linear-gradient(180deg, var(--tecfesa-blue), var(--tecfesa-green));content:"";border-radius:999px;width:4px;height:62%;position:absolute;top:19%;left:0}.capture-title-copy{min-width:0}.capture-title-card h1{font-size:clamp(30px,7.2vw,52px)}.capture-meta-line{color:#557084;margin-top:10px;font-size:14px;font-weight:800}.capture-progress-card{color:var(--tecfesa-blue);background:#ffffffad;border:1px solid #0060a814;border-radius:22px;place-items:center;min-width:84px;padding:12px;display:grid}.capture-progress-card span{letter-spacing:-.05em;font-size:22px;font-weight:900}.capture-progress-card small{color:#557084;text-align:center;font-size:11px;font-weight:760}.capture-pills{flex-wrap:wrap;gap:8px;margin-top:16px;display:flex}.capture-pills span,.new-status-badge,.draft-status-badge,.admin-badge{border-radius:999px;padding:8px 11px;font-size:13px;font-weight:850;display:inline-flex}.capture-pills span,.draft-status-badge{color:#344054;background:#eef4f7}.new-status-badge,.admin-badge{color:#166534;background:#dcfce7}.camera-card{background:radial-gradient(circle at 16% 0,#0060a82e,#0000 16rem),radial-gradient(circle at 92% 6%,#13a66b21,#0000 14rem),linear-gradient(145deg,#ffffffdb,#ffffff9e);gap:18px;padding:22px;display:grid}.camera-copy h2{margin-bottom:8px}.camera-copy p:last-child{margin:0;font-size:17px;line-height:1.42}.photo-source-grid{grid-template-columns:1fr;gap:12px;display:grid}.compact-photo-source-grid{gap:10px}.compact-photo-source-grid .big-photo-button{min-height:104px;font-size:18px}.compact-photo-source-grid .secondary-photo-button{min-height:56px}.big-photo-button,.secondary-photo-button{cursor:pointer;text-align:center;border-radius:26px;justify-content:center;align-items:center;font-weight:850;display:flex}.big-photo-button{background:radial-gradient(circle at 22% 0%, #ffffff42, transparent 34%), linear-gradient(135deg, var(--tecfesa-blue), #087f9d 52%, var(--tecfesa-green));color:#fff;flex-direction:column;gap:9px;min-height:172px;font-size:23px;position:relative;box-shadow:0 22px 48px #0060a83d}.big-photo-button small,.secondary-photo-button small{color:#ffffffc7;font-size:13px;font-weight:700}.secondary-photo-button{color:var(--tecfesa-blue);background:#e9f6ffbd;border:1px solid #0060a814;gap:10px;min-height:66px}.small-source-icon{width:28px;height:28px}.big-photo-button input,.secondary-photo-button input{display:none}.empty-photos{color:#667085;text-align:center;background:#ffffff8a;border:1.5px dashed #0060a83d;border-radius:28px;align-items:center;gap:6px;padding:30px;display:grid}.empty-photos strong{color:#1d3954}.photo-stack{gap:18px;display:grid}.add-more-card{background:radial-gradient(circle at 92% 0,#13a66b1f,#0000 10rem),#ffffffb3;gap:16px;display:grid}.add-more-card h2,.work-summary-card h2{margin-bottom:8px}.add-more-card p:last-child,.work-summary-card p:last-of-type{color:#667085;margin-bottom:14px;font-size:16px;line-height:1.42}.work-summary-card{background:radial-gradient(circle at 12% 0,#0060a81f,#0000 12rem),linear-gradient(145deg,#ffffffe0,#ffffffa3)}.internal-notes-card{background:radial-gradient(circle at 88% 0,#13a66b1a,#0000 11rem),linear-gradient(145deg,#ffffffd1,#f5fafd9e)}.work-summary-card textarea{min-height:160px}.photo-card{border-color:#0060a81a;gap:0;padding:0;display:grid;overflow:hidden}.photo-card.needs-note{border-color:#f59e0b57}.field-invalid{box-shadow:0 0 0 4px #b4231814,0 20px 60px #b423181a;border-color:#b42318b8!important}.field-invalid textarea{border-color:#b42318c2;box-shadow:0 0 0 4px #b4231814}.field-error-text{background:#ffe4e6b8;border:1px solid #b423182e;border-radius:14px;align-items:center;gap:7px;padding:9px 11px;display:inline-flex;color:#9f1239!important;margin:4px 0 0!important;font-size:13px!important;font-weight:850!important;line-height:1.35!important}.field-error-text:before{color:#fff;content:"!";background:#b42318;border-radius:999px;flex:none;place-items:center;width:18px;height:18px;font-size:11px;display:inline-grid}.photo-card.complete{border-color:#13a66b52}.photo-media{background:#e8eef4;min-height:220px;position:relative;overflow:hidden}.photo-media img,.photo-card img{aspect-ratio:4/3;object-fit:cover;background:#eef2f7;width:100%}.photo-media img{height:100%;display:block}.photo-number{color:#fff;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:linear-gradient(135deg,#0060a8e0,#13a66bd1);border:1px solid #fff3;border-radius:999px;padding:8px 11px;font-size:13px;font-weight:820;position:absolute;bottom:12px;left:12px}.photo-content{gap:14px;padding:16px;display:grid}.photo-index{color:var(--tecfesa-blue);justify-content:space-between;align-items:center;font-weight:850;display:flex}.photo-index>span{align-items:center;gap:6px;display:inline-flex}.status-icon{color:#166534;background:#dcfce7;border-radius:999px;width:22px;height:22px;padding:3px}.photo-index small{color:#557084;background:#eef6f7;border-radius:999px;padding:6px 9px;font-size:12px}.field-help{color:#667085;font-size:13px;font-weight:600}.photo-card textarea{background:#fffffff5;min-height:142px}.photo-actions{grid-template-columns:1fr;gap:10px;display:grid}.text-danger-button,.danger-button{box-shadow:none;color:#b42318;background:0 0}.work-summary-card textarea,.internal-notes-card textarea{min-height:150px}.quiet-meta-card{box-shadow:none}.quiet-meta-card summary,.advanced-draft-panel summary{color:#344054;cursor:pointer;font-weight:850}.done-card{color:#166534;background:#ecfdf3;align-items:flex-start;gap:4px;display:grid}.error-message,.success-message{border-radius:20px;margin:0;padding:14px 16px;font-weight:750}.error-message{color:#9f1239;background:#ffe4e6}.success-message{color:#166534;background:#ecfdf3}.section-header{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.list,.clean-list,.user-details{gap:12px;display:grid}.list-item{color:inherit;border:1px solid #11182714;border-radius:20px;gap:4px;padding:16px;text-decoration:none;display:grid}.report-list-item{grid-template-columns:1fr auto;align-items:center}.report-list-item>div{gap:3px;min-width:0;display:grid}.report-list-item span,.report-list-item small{line-height:1.45;display:block}.list-item strong,.user-details dd{color:var(--ink);font-weight:850}.list-item span,.list-item small,.user-details dt{color:#667085}.user-details{margin:0}.user-details div{gap:4px;display:grid}.user-details dd{margin:0}.compact-details{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.muted-panel{box-shadow:none}.dynamic-form,.form-section{gap:14px;display:grid}.form-section{border:1px solid #11182714;border-radius:18px;margin:0;padding:16px}.table-wrapper{overflow-x:auto}table{border-collapse:collapse;width:100%}th,td{text-align:left;border-bottom:1px solid #11182714;padding:10px}@media (width<=420px){.home-flow{gap:6px}.home-flow-step{border-radius:17px;padding:8px 5px}.home-flow-step small{display:none}.capture-title-card{grid-template-columns:1fr}.capture-progress-card{justify-items:start;min-width:0}}@media (width>=760px){.app-shell{padding:24px 28px 120px}.home-screen{min-height:calc(100svh - 150px)}.photo-source-grid,.photo-actions{grid-template-columns:1.35fr 1fr}.photo-card{grid-template-columns:minmax(280px,.9fr) 1.1fr}.photo-media{min-height:100%}}
