:root{--bg:#ffffff;--panel:#f4f4f4;--border:#d4d4d4;--border-bright:#b0b0b0;--accent:#111111;--accent-dim:#555555;--accent-glow:rgba(0,0,0,.06);--text:#111111;--text-dim:#555555;--text-muted:#999999;--green:#1e7a40;--red:#c0392b;--mono:"Share Tech Mono",monospace;--sans:"Barlow Condensed",sans-serif;--body:"Barlow",sans-serif;--thead-bg:#ebebeb;--val-drop:#b02a1a;--val-vel:#1a6090;--val-energy:#6e3a8a;--val-toi:#1a6090;--val-drift:#7a5000;--syw-res:#1e7a40;--syw-con:#1a6090;--row-hover:rgba(0,0,0,.04);--row-major:rgba(0,0,0,.05);--row-transonic-bg:rgba(180,100,20,.1);--row-transonic-fg:#a0621a;--row-subsonic-bg:rgba(40,100,180,.1);--row-subsonic-fg:#1a60a0;--syw-hover:rgba(0,0,0,.06);--rc-transonic:rgba(180,100,20,.08);--rc-subsonic:rgba(40,100,180,.08);--select-option-bg:#ffffff}body.dark{--bg:#0a0c0e;--panel:#0f1214;--border:#1e2428;--border-bright:#2a3540;--accent:#c8a84b;--accent-dim:#7a6228;--accent-glow:rgba(200,168,75,.12);--text:#d4cfc8;--text-dim:#6b6860;--text-muted:#3a3830;--green:#4caf7d;--red:#c0392b;--thead-bg:#0c0e10;--val-drop:#e07060;--val-vel:#7ab8d4;--val-energy:#c87ad4;--val-toi:#9ab8d4;--val-drift:#d4a84b;--syw-res:#4caf7d;--syw-con:#7ab8d4;--row-hover:rgba(200,168,75,.04);--row-major:rgba(200,168,75,.06);--row-transonic-bg:rgba(200,120,40,.13);--row-transonic-fg:#d4924a;--row-subsonic-bg:rgba(100,140,200,.13);--row-subsonic-fg:#7aabd4;--syw-hover:rgba(200,168,75,.06);--rc-transonic:rgba(200,120,40,.09);--rc-subsonic:rgba(100,140,200,.09);--select-option-bg:#1a1e22}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:var(--body);min-height:100vh;overflow-x:hidden}body.dark:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.07) 2px,rgba(0,0,0,.07) 4px);pointer-events:none;z-index:1000}.header{border-bottom:1px solid var(--border);padding:20px 40px;display:flex;align-items:center;justify-content:space-between;position:relative}.header:after{content:"";position:absolute;bottom:-1px;left:0;width:100%;height:1px;background:linear-gradient(90deg,var(--border-bright) 0%,transparent 60%);opacity:.8}.logo{display:flex;align-items:baseline;gap:14px}.logo-title{font-family:var(--sans);font-weight:700;font-size:22px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}.theme-toggle{display:flex;align-items:center;gap:8px;font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted)}.theme-toggle-track{position:relative;width:36px;height:20px;background:var(--border);border-radius:10px;cursor:pointer;transition:background .2s;flex-shrink:0;border:1px solid var(--border-bright)}.theme-toggle-track.dark{background:var(--accent-dim)}.theme-toggle-thumb{position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:var(--text-dim);transition:transform .2s,background .2s}.theme-toggle-track.dark .theme-toggle-thumb{transform:translate(16px);background:var(--accent)}.unit-radio-group{display:flex;gap:6px}.unit-radio-btn{flex:1;padding:7px 10px;background:var(--panel);border:1px solid var(--border);border-radius:3px;color:var(--text-muted);font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;text-align:center;transition:all .15s;-webkit-user-select:none;user-select:none}.unit-radio-btn.active{background:var(--accent);color:var(--bg);border-color:var(--accent)}body.show-moa .col-mil,body.show-mil .col-moa{display:none}.main{display:grid;grid-template-columns:340px 1fr;min-height:calc(100vh - 65px)}.inputs-panel{border-right:1px solid var(--border);padding:32px 28px;display:flex;flex-direction:column;gap:28px}.section-label{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--accent-dim);margin-bottom:14px;display:flex;align-items:center;gap:8px}.section-label:after{content:"";flex:1;height:1px;background:var(--border)}.field{margin-bottom:16px}.field label{display:block;font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);margin-bottom:6px}.field-unit{font-family:var(--mono);font-size:10px;color:var(--text-muted);letter-spacing:.05em;margin-left:6px;font-weight:400;text-transform:none}.input-wrap{position:relative;display:flex;align-items:center}.input-wrap input{width:100%;background:var(--panel);border:1px solid var(--border);border-radius:3px;color:var(--text);font-family:var(--mono);font-size:16px;padding:10px 52px 10px 14px;outline:none;transition:border-color .2s,box-shadow .2s;-moz-appearance:textfield}.input-wrap input::-webkit-inner-spin-button,.input-wrap input::-webkit-outer-spin-button{-webkit-appearance:none}.input-wrap input:focus{border-color:var(--accent-dim);box-shadow:0 0 0 2px var(--accent-glow)}.input-unit{position:absolute;right:12px;font-family:var(--mono);font-size:11px;color:var(--text-muted);pointer-events:none}.range-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}.calculate-btn{width:100%;padding:14px;background:transparent;border:1px solid var(--accent-dim);border-radius:3px;color:var(--accent);font-family:var(--sans);font-size:15px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;transition:all .2s;position:relative;overflow:hidden}.calculate-btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--accent-glow);opacity:0;transition:opacity .2s}.calculate-btn:hover:before{opacity:1}.calculate-btn:hover{border-color:var(--accent);box-shadow:0 0 20px var(--accent-glow)}.calculate-btn:active{transform:scale(.99)}.output-panel{padding:32px 36px;display:flex;flex-direction:column;gap:24px}.output-header{display:flex;align-items:baseline;justify-content:space-between}.output-title{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--accent-dim)}.output-meta{font-family:var(--mono);font-size:10px;color:var(--text-muted)}.summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.summary-card{background:var(--panel);border:1px solid var(--border);border-radius:3px;padding:14px 16px}.summary-card-label{font-family:var(--mono);font-size:10px;color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;margin-bottom:6px}.summary-card-value{font-family:var(--mono);font-size:22px;color:var(--accent);letter-spacing:-.02em}.summary-card-unit{font-size:11px;color:var(--accent-dim);margin-left:3px}.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:3px}table{width:100%;border-collapse:collapse;font-family:var(--mono);font-size:13px}thead tr{border-bottom:1px solid var(--border-bright);background:var(--thead-bg)}thead th{text-align:right;padding:10px 16px;font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--text-dim);white-space:nowrap}thead th:first-child{text-align:left}tbody tr{border-bottom:1px solid var(--border);transition:background .1s}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:var(--row-hover)}tbody tr.major-range{background:var(--row-major)}tbody tr.major-range td:first-child{color:var(--accent)}tbody td{text-align:right;padding:8px 16px;color:var(--text)}tbody td:first-child{text-align:left;color:var(--text-dim);font-size:12px}.val-drop{color:var(--val-drop)}.val-vel{color:var(--val-vel)}.val-moa,.val-mil{color:var(--accent);font-weight:700}.val-energy{color:var(--val-energy)}.val-tof{color:var(--text-dim)}.val-toi{color:var(--val-toi)}.val-drift{color:var(--val-drift)}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-muted);min-height:400px}.empty-reticle{width:64px;height:64px;position:relative;opacity:.3}.empty-reticle:before,.empty-reticle:after{content:"";position:absolute;background:var(--text-muted)}.empty-reticle:before{left:50%;top:0;width:1px;height:100%;transform:translate(-50%)}.empty-reticle:after{top:50%;left:0;height:1px;width:100%;transform:translateY(-50%)}.empty-circle{position:absolute;top:8px;right:8px;bottom:8px;left:8px;border-radius:50%;border:1px solid var(--text-muted)}.empty-circle2{position:absolute;top:22px;right:22px;bottom:22px;left:22px;border-radius:50%;border:1px solid var(--text-muted)}.empty-label{font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--text-muted)}.atmo-bar{display:flex;gap:18px;background:var(--panel);border:1px solid var(--border);border-radius:3px;padding:10px 16px;font-family:var(--mono);font-size:11px;color:var(--text-dim);flex-wrap:wrap}.atmo-item{display:flex;gap:6px;align-items:center}.atmo-key{color:var(--text-muted);text-transform:uppercase;font-size:10px;letter-spacing:.08em}.atmo-val{color:var(--text)}.da-badge{margin-left:auto;font-family:var(--mono);font-size:10px;padding:3px 8px;border-radius:2px;background:#c8a84b1a;color:var(--accent-dim);letter-spacing:.06em;border:1px solid var(--border)}.hidden{display:none!important}.error-msg{font-family:var(--mono);font-size:12px;color:var(--red);padding:10px 14px;border:1px solid var(--red);border-radius:3px;background:#c0392b12}.preset-select{width:100%;background:var(--panel);border:1px solid var(--border);border-radius:3px;color:var(--text);font-family:var(--mono);font-size:13px;padding:9px 12px;outline:none;cursor:pointer;transition:border-color .2s;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23555555'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.preset-select:focus{border-color:var(--accent-dim)}.preset-select option{background:var(--select-option-bg);color:var(--text)}tbody tr.transonic{background:var(--row-transonic-bg)}tbody tr.transonic td:first-child{color:var(--row-transonic-fg)}tbody tr.subsonic{background:var(--row-subsonic-bg)}tbody tr.subsonic td:first-child{color:var(--row-subsonic-fg)}.syw-wrap{border:1px solid var(--border);border-radius:3px;overflow:hidden}.syw-toggle{width:100%;background:var(--panel);border:none;color:var(--text-dim);font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;padding:12px 16px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:background .15s}.syw-toggle:hover{background:var(--syw-hover)}.syw-chevron{transition:transform .25s;font-size:10px;color:var(--accent-dim)}.syw-toggle.open .syw-chevron{transform:rotate(180deg)}.syw-body{display:none;padding:24px 20px;flex-direction:column;gap:20px;background:var(--bg)}.syw-body.open{display:flex}.syw-section-title{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-dim);margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border)}.syw-block{background:var(--panel);border:1px solid var(--border);border-radius:3px;padding:14px 16px}.syw-label{font-family:var(--sans);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:5px}.syw-eq{font-family:var(--mono);font-size:12px;line-height:2;color:var(--text-dim)}.syw-eq .sym{color:var(--text)}.syw-eq .num{color:var(--accent)}.syw-eq .res{color:var(--syw-res);font-weight:700}.syw-eq .con{color:var(--syw-con);font-style:italic}.syw-note{font-family:var(--body);font-size:12px;color:var(--text-muted);line-height:1.6;padding:6px 10px;border-left:2px solid var(--border);margin-top:8px}.syw-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.save-row{display:flex;gap:8px;margin-bottom:14px}.save-input{flex:1;background:var(--panel);border:1px solid var(--border);border-radius:3px;color:var(--text);font-family:var(--mono);font-size:13px;padding:9px 12px;outline:none;transition:border-color .2s;min-width:0}.save-input:focus{border-color:var(--accent-dim)}.save-input::placeholder{color:var(--text-muted)}.save-btn{background:transparent;border:1px solid var(--border);border-radius:3px;color:var(--text-dim);font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:9px 12px;cursor:pointer;white-space:nowrap;transition:all .15s;flex-shrink:0}.save-btn:hover:not(:disabled){border-color:var(--border-bright);color:var(--text)}.save-btn:disabled{opacity:.35;cursor:default}.saved-rifle-list{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}.saved-rifle-item{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:5px 8px;background:var(--panel);border:1px solid var(--border);border-radius:3px}.saved-rifle-name{font-family:var(--mono);font-size:12px;color:var(--text-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.range-card-btn{width:100%;padding:11px;background:transparent;border:1px solid var(--border);border-radius:3px;color:var(--text-dim);font-family:var(--sans);font-size:14px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;transition:all .2s;margin-top:8px}.range-card-btn:hover{border-color:var(--border-bright);color:var(--text);background:var(--row-hover)}.rc-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px}.rc-add-stage{background:transparent;border:1px solid var(--accent-dim);border-radius:3px;color:var(--accent);font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;padding:8px 16px;cursor:pointer;transition:all .2s}.rc-add-stage:hover{border-color:var(--accent);box-shadow:0 0 12px var(--accent-glow)}.rc-stage{background:var(--panel);border:1px solid var(--border);border-radius:3px;margin-bottom:16px;overflow:hidden}.rc-stage-header{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--thead-bg)}.rc-stage-name{background:transparent;border:none;border-bottom:1px solid var(--border);color:var(--text);font-family:var(--sans);font-size:16px;font-weight:600;letter-spacing:.06em;padding:2px 4px;outline:none;flex:1;min-width:0;transition:border-color .2s}.rc-stage-name:focus{border-color:var(--accent-dim)}.rc-stage-name::placeholder{color:var(--text-muted)}.rc-stage-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}.rc-btn{background:transparent;border:1px solid var(--border);border-radius:3px;color:var(--text-dim);font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:5px 10px;cursor:pointer;transition:all .15s;white-space:nowrap}.rc-btn:hover{border-color:var(--border-bright);color:var(--text)}.rc-btn.danger:hover{border-color:var(--red);color:var(--red)}.rc-targets{width:100%}.rc-targets thead tr{background:var(--thead-bg);border-bottom:1px solid var(--border)}.rc-targets thead th{font-family:var(--sans);font-size:10px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted);padding:8px 12px;text-align:left}.rc-targets thead th:not(:first-child){text-align:right}.rc-targets tbody tr{border-bottom:1px solid var(--border)}.rc-targets tbody tr:last-child{border-bottom:none}.rc-targets tbody tr:hover{background:var(--row-hover)}.rc-targets tbody td{padding:7px 12px;font-family:var(--mono);font-size:12px;color:var(--text-dim);text-align:right}.rc-targets tbody td:first-child{text-align:left}.rc-targets tbody td:nth-child(2){color:var(--text)}.rc-target-input{background:transparent;border:none;border-bottom:1px solid transparent;color:var(--text);font-family:var(--mono);font-size:12px;width:100%;outline:none;text-align:left;padding:1px 2px;transition:border-color .15s}.rc-target-input:focus{border-color:var(--accent-dim)}.rc-target-input.num{text-align:right;width:70px}.rc-target-input::placeholder{color:var(--text-muted)}.rc-add-target-row{padding:8px 12px;border-top:1px solid var(--border)}.rc-add-target-btn{background:transparent;border:none;color:var(--text-muted);font-family:var(--mono);font-size:11px;cursor:pointer;padding:2px 4px;transition:color .15s;letter-spacing:.06em}.rc-add-target-btn:hover,.rc-val-mil,.rc-val-moa{color:var(--accent)}.rc-val-drift{color:var(--val-drift)}.rc-val-drop{color:var(--val-drop)}.rc-val-vel{color:var(--val-vel)}.rc-transonic td{background:var(--rc-transonic)!important}.rc-subsonic td{background:var(--rc-subsonic)!important}.rc-no-data{color:var(--text-muted);font-style:italic;font-size:11px}@media(max-width:900px){.main{grid-template-columns:1fr}.inputs-panel{border-right:none;border-bottom:1px solid var(--border)}.summary-grid{grid-template-columns:1fr 1fr}.syw-grid{grid-template-columns:1fr}}@media(orientation:portrait)and (max-width:768px){.col-energy,.col-tof,.col-toi,.col-drop{display:none}.header{padding:14px 18px}.logo-title{font-size:18px}.main{grid-template-columns:1fr}.inputs-panel{border-right:none;border-bottom:1px solid var(--border);padding:20px 16px;gap:20px}.output-panel{padding:20px 16px;gap:16px}.summary-grid{grid-template-columns:1fr 1fr}.syw-grid{grid-template-columns:1fr}.range-row{grid-template-columns:1fr 1fr 1fr}table{font-size:12px}thead th{padding:8px 10px;font-size:10px}tbody td{padding:7px 10px}}
