/* CADDY LOGIC v1.0.4 Beta — Premium dark aesthetic, sunlight-readable, glove-friendly
   Metallic gradients. Card flips. SVG icons. Zero emojis. Zero rounded corners on actions.
   All text min 10px. Touch targets min 44px. High contrast for outdoor play. */
:root {
  --black: #000; --charcoal: #0A0A08;
  --gold: #C9A84C; --silver: #D0D0C8; --copper: #D4845A;
  --green: #5DAA68; --red: #D94F4F; --blue: #6BA4D9;
  --text: #E8E8E0; --text-dim: #B0B0A8; --text-dimmer: #777;
  --border: #222; --border-light: #333;
  --font: -apple-system, BlinkMacSystemFont, 'SF Pro Display', 'Helvetica Neue', sans-serif;
  --serif: Georgia, 'Times New Roman', serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;background:var(--black);color:var(--text);font-family:var(--font);-webkit-font-smoothing:antialiased;overflow:hidden;user-select:none;-webkit-user-select:none;touch-action:manipulation;font-size:16px}
body{overscroll-behavior-y:contain}
.mg{background:linear-gradient(135deg,#B8942E,#E8D48B 38%,#C9A84C 52%,#F0E2A0 70%,#B8942E);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.ms{color:var(--text)}.mc{background:linear-gradient(135deg,#A06030,#E8A878 35%,#D4845A 50%,#EEBB90 68%,#A06030);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
#app{height:100%;max-width:430px;margin:0 auto;display:flex;flex-direction:column;position:relative;overflow:hidden}
.safe-top{padding-top:env(safe-area-inset-top,0px);background:var(--black)}
.hidden{display:none!important}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}.fade-in{animation:fadeIn .3s ease}

/* SPLASH */
#splash{position:fixed;inset:0;z-index:9999;background:var(--black);display:flex;flex-direction:column;align-items:center;justify-content:center;transition:opacity .6s}
#splash.fade{opacity:0;pointer-events:none}
.splash-bib{border:2px solid;border-image:linear-gradient(135deg,#6B4420,#D4845A,#E8A878,#D4845A,#6B4420) 1;padding:18px 32px}
.splash-text{font-size:22px;font-weight:700;letter-spacing:.14em;text-align:center;line-height:1.3}
.splash-tagline{font-family:var(--serif);font-style:italic;font-size:12px;margin-top:12px}
#landscape-warn{display:none;position:fixed;inset:0;z-index:10000;background:var(--black);flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem}
#landscape-warn p{color:var(--silver);font-size:14px}
@media(orientation:landscape) and (max-height:500px){#landscape-warn{display:flex!important}}

/* COMMIT FLASH */
@keyframes commitFlash{0%{opacity:.5}100%{opacity:0}}
.commit-flash{position:absolute;inset:0;z-index:35;pointer-events:none;animation:commitFlash .4s ease forwards}
.commit-flash.smart{background:rgba(93,170,104,.15)}.commit-flash.hero{background:rgba(212,132,90,.15)}

/* BANNER */
.banner{display:flex;justify-content:space-between;align-items:center;padding:8px 14px;border-bottom:1px solid #111;background:var(--black);z-index:10;min-height:48px}
.banner.faded{opacity:.25;pointer-events:none}
.banner-left,.banner-right{display:flex;align-items:center;gap:6px}
.hamburger{display:flex;flex-direction:column;gap:3px;padding:8px;cursor:pointer;min-width:44px;min-height:44px;justify-content:center;background:none;border:none}
.hamburger div{height:2px;background:linear-gradient(90deg,#A06030,#E8A878,#D4845A);border-radius:1px}
.hamburger div:nth-child(1){width:18px}.hamburger div:nth-child(2){width:13px}.hamburger div:nth-child(3){width:18px}
.bib{border:1.5px solid;border-image:linear-gradient(135deg,#6B4420,#D4845A,#E8A878,#D4845A,#6B4420) 1;padding:4px 12px;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer}
.bib-text{font-size:11px;font-weight:600;letter-spacing:.14em}
.hole-counter{display:flex;align-items:center;gap:4px;padding:4px 8px;border:1px solid var(--border);border-radius:4px;cursor:pointer;min-height:44px}
.hole-num{font-size:16px;font-weight:600}.hole-label{font-size:9px;color:var(--text-dim)}
.weather-btn{display:flex;align-items:center;gap:3px;padding:4px 6px;border:1px solid var(--border);border-radius:4px;cursor:pointer;min-height:44px;min-width:44px;justify-content:center;background:none}
.wind-label{font-size:10px;font-family:monospace;font-weight:600;color:var(--text-dim)}

/* SCREENS */
.screen{flex:1;display:flex;flex-direction:column;padding:0 14px;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}

/* BUTTONS */
.btn-primary{width:100%;padding:16px;border:1px solid #2a4a2a;background:linear-gradient(135deg,#1a2510,#0a1208);color:var(--green);font-family:var(--font);font-size:15px;font-weight:600;letter-spacing:.08em;cursor:pointer;border-radius:0;min-height:48px;transition:transform .1s}
.btn-primary:active{transform:scale(.97)}
.btn-secondary{width:100%;padding:14px;border:1px solid var(--border);background:#0a0a08;color:var(--text-dim);font-family:var(--font);font-size:13px;font-weight:500;cursor:pointer;border-radius:0;min-height:48px}
.btn-hero{width:100%;padding:14px;border:1px solid #2a1a10;background:linear-gradient(135deg,#1a0e06,#0e0804);color:var(--copper);font-family:var(--font);font-size:14px;font-weight:600;letter-spacing:.06em;cursor:pointer;border-radius:0;min-height:48px;transition:transform .1s}
.btn-hero:active{transform:scale(.97)}
.btn-danger{width:100%;padding:14px;border:1px solid #3a1a1a;background:linear-gradient(135deg,#2a0a0a,#1a0606);color:var(--red);font-family:var(--font);font-size:14px;font-weight:600;cursor:pointer;border-radius:0;min-height:48px}
.btn-back{font-size:13px;color:var(--text-dim);cursor:pointer;display:flex;align-items:center;gap:4px;padding:8px 0;min-height:44px;background:none;border:none;font-family:var(--font)}

/* INPUT */
.yardage-area{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center}
.yardage-row{display:flex;align-items:center;gap:14px}
.yrd-adjust{padding:10px 16px;border:1px solid var(--border);border-radius:4px;font-size:22px;color:var(--text-dim);cursor:pointer;background:none;font-family:var(--font);line-height:1;min-width:48px;min-height:48px;display:flex;align-items:center;justify-content:center}
.yrd-adjust:active{background:#111}
.yardage-num{font-size:64px;font-weight:600;line-height:1;cursor:pointer;text-align:center;min-width:140px}
.yardage-label{font-size:11px;color:var(--text-dim);letter-spacing:.1em;margin-top:4px;text-align:center}
.quick-jumps{display:flex;gap:4px;margin-top:10px;flex-wrap:wrap;justify-content:center}
.qj-btn{padding:6px 10px;border:1px solid var(--border);border-radius:4px;font-size:12px;color:var(--text-dim);cursor:pointer;background:none;font-family:var(--font);min-height:36px}
.qj-btn.active{color:var(--gold);border-color:#3a3a20}.qj-btn:active{background:#111}
.skip-btn{font-size:11px;color:var(--text-dimmer);padding:6px 12px;border:1px solid var(--border);border-radius:4px;cursor:pointer;margin-top:6px;background:none;font-family:var(--font);min-height:36px}

.elev-row{display:flex;gap:4px;align-items:center;margin-top:8px;padding-top:8px;border-top:1px solid #111;flex-wrap:wrap}
.elev-label{font-size:10px;color:var(--text-dimmer);line-height:1.2;margin-right:4px}
.elev-btn{padding:6px 10px;border:1px solid var(--border);border-radius:4px;font-size:11px;color:var(--text-dim);cursor:pointer;background:none;font-family:var(--font);min-height:36px}
.elev-btn.active-up{color:var(--green);border-color:#2a4a2a;background:rgba(93,170,104,.06)}
.elev-btn.active-dn{color:var(--red);border-color:#3a1a1a;background:rgba(217,79,79,.06)}

.conditions-area{border-top:1px solid #111;padding:6px 0}
.cond-row{display:flex;gap:3px;margin-bottom:3px}
.cond-icon{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 2px 5px;border:1.5px solid var(--border);border-radius:4px;cursor:pointer;flex:1;min-width:0;min-height:50px;justify-content:center;transition:all .15s}
.cond-icon.on{border-color:#2a4a2a;background:rgba(93,170,104,.06)}
.cond-icon.on .ci-label,.cond-icon.on .ci-mod{color:var(--green)!important}
.cond-icon.on svg path,.cond-icon.on svg line,.cond-icon.on svg circle,.cond-icon.on svg ellipse{stroke:var(--green)!important}
.ci-mod{font-size:10px;font-family:monospace;font-weight:600;color:var(--text-dim)}
.ci-label{font-size:10px;color:var(--text-dim);font-weight:500;text-align:center}
.temp-group{display:flex;gap:4px}
.temp-btn{padding:6px 12px;border:1px solid var(--border);border-radius:4px;font-size:12px;color:var(--text-dim);cursor:pointer;background:none;font-family:var(--font);min-height:36px;font-weight:500}
.temp-btn.hot.active{color:var(--red);border-color:#3a1a1a;background:rgba(217,79,79,.06)}
.temp-btn.mild.active{color:var(--green);border-color:#2a4a2a;background:rgba(93,170,104,.06)}
.temp-btn.cold.active{color:var(--blue);border-color:#1a2a3a;background:rgba(107,164,217,.06)}

/* OUTPUT — Cards */
.trust-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0;border-bottom:1px solid #111;cursor:pointer}
.trust-yardage{font-size:22px;font-weight:600}.trust-yds{font-size:10px;color:var(--text-dim);margin-left:2px}
.trust-mods{display:flex;gap:6px;align-items:center}
.trust-mod-num{font-size:11px;font-family:monospace;font-weight:600}
.trust-total{font-size:18px;font-weight:600}.trust-eq{font-size:11px;color:var(--text-dim)}.trust-edit{font-size:10px;color:var(--text-dimmer)}

.situation-summary{padding:6px 0;border-bottom:1px solid #111;font-size:13px;line-height:1.4}
.sit-tag{display:inline-block;padding:2px 8px;border:1px solid var(--border);border-radius:3px;font-size:11px;margin:2px 2px 2px 0;font-weight:500}
.sit-tag.terrain{color:var(--green);border-color:#2a4a2a}.sit-tag.slope{color:var(--blue);border-color:#1a2a3a}
.sit-tag.obstacle{color:var(--copper);border-color:#3a2010}.sit-tag.wind{color:var(--silver);border-color:#333}

.club-call{text-align:center;padding:6px 0}
.club-name-display{font-size:42px;font-weight:600;line-height:1}
.conf-bar{width:44px;height:5px;background:#1a1a18;border-radius:3px;overflow:hidden}
.conf-fill{height:100%;border-radius:3px;transition:width .3s}
.conf-fill.green{background:linear-gradient(90deg,#3a7a42,var(--green))}
.conf-fill.red{background:linear-gradient(90deg,#993322,var(--red))}

/* FLIP CARDS */
.cards-row{display:flex;gap:6px;flex:1;min-height:180px;margin-bottom:4px}
.card-wrap{perspective:800px;cursor:pointer;flex:1;min-height:0}
.card-inner{position:relative;width:100%;height:100%;transition:transform .5s cubic-bezier(.4,0,.2,1);transform-style:preserve-3d}
.card-inner.flipped{transform:rotateY(180deg)}
.card-front,.card-back{position:absolute;top:0;left:0;right:0;bottom:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;display:flex;flex-direction:column;overflow:hidden;border-radius:4px}
.card-back{transform:rotateY(180deg)}
.card-header{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;border-bottom:1px solid}
.card-header-text{font-size:11px;letter-spacing:.08em;font-weight:600}
.card-body{padding:10px;flex:1;display:flex;flex-direction:column;justify-content:center}
.card-text{font-size:14px;line-height:1.55}
.card-kicker{font-family:var(--serif);font-style:italic;font-size:12px;margin-top:8px}
.card-footer{padding:4px 10px;border-top:1px solid;text-align:center;font-size:10px;color:#555}

.card-smart .card-front{background:var(--black);border:1.5px solid;border-image:linear-gradient(160deg,#555,#999,#666,#888,#555) 1}
.card-smart .card-header{border-color:#1a1a18}.card-smart .card-footer{border-color:#1a1a18}
.card-hero .card-front{background:var(--black);border:1.5px solid;border-image:linear-gradient(160deg,#3a2010,var(--copper),#3a2010) 1}
.card-hero .card-header{border-color:#201510}.card-hero .card-footer{border-color:#201510;color:#3a2818}
.card-smart .card-back{background:#020201;border:1.5px solid;border-image:linear-gradient(160deg,#6B5010,var(--gold),#6B5010) 1}
.card-hero .card-back{background:#030201;border:1.5px solid;border-image:linear-gradient(160deg,#3a2010,var(--copper),#3a2010) 1}

.setup-header{padding:4px 10px;border-bottom:1px solid #111;font-size:10px;letter-spacing:.1em;font-weight:600}
.setup-body{padding:6px 10px;flex:1;display:flex;flex-direction:column;overflow-y:auto}
.setup-row{display:flex;gap:6px;align-items:flex-start;padding:4px 0;border-bottom:1px solid #0a0a08}
.setup-row:last-of-type{border-bottom:none}
.setup-label{font-size:10px;font-weight:600;min-width:34px}
.setup-value{font-size:12px;line-height:1.4}
.remember-section,.danger-section{border-top:1px solid #111;padding-top:4px;margin-top:auto}
.remember-label{font-size:10px;font-weight:600;color:var(--green);letter-spacing:.06em}
.danger-label{font-size:10px;font-weight:600;color:var(--red);letter-spacing:.06em}
.remember-text,.danger-text{font-size:11px;line-height:1.35;color:var(--text-dim);margin-top:2px}
.closing-kicker{margin-top:auto;padding-top:4px;border-top:1px solid #111;font-family:var(--serif);font-style:italic;font-size:11px;line-height:1.3}
.commit-area{padding:0 0 4px}.commit-area .btn-primary{margin-bottom:4px}

/* SUB-PANELS */
.sub-panel{position:absolute;bottom:0;left:0;right:0;background:#050503;border-top:2px solid;border-image:linear-gradient(90deg,#6B4420,#D4845A,#E8A878,#D4845A,#6B4420) 1;border-radius:16px 16px 0 0;padding:14px 16px 24px;z-index:30;transform:translateY(100%);transition:transform .3s ease}
.sub-panel.open{transform:translateY(0)}
.sub-handle{width:40px;height:4px;background:#444;border-radius:2px;margin:0 auto 12px}
.sub-title{font-size:14px;font-weight:600;letter-spacing:.08em;margin-bottom:4px}
.sub-desc{font-size:12px;color:var(--text-dim);margin-bottom:12px}
.sub-close{background:none;border:none;font-size:18px;color:var(--text-dim);cursor:pointer;padding:4px 8px;min-height:44px;min-width:44px;display:flex;align-items:center;justify-content:center}
.sub-option{border:1.5px solid var(--border);border-radius:6px;padding:14px;margin-bottom:8px;cursor:pointer;min-height:48px}
.sub-option:active{background:#0a0a08}
.sub-option-label{font-size:14px;font-weight:600}.sub-option-desc{font-size:11px;color:var(--text-dim);margin-top:2px}
.dir-row{display:flex;gap:8px;margin-top:8px}
.dir-btn{flex:1;padding:12px;border:1.5px solid var(--border);border-radius:6px;text-align:center;cursor:pointer;background:none;font-family:var(--font);min-height:48px}
.dir-btn:active{background:#0a0a08}
.dir-label{font-size:13px;font-weight:600}.dir-sub{font-size:10px;color:var(--text-dim);margin-top:2px}

/* Wind popup */
.wind-popup{position:absolute;inset:0;background:rgba(0,0,0,.95);z-index:40;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px}
.wind-popup-card{background:#050503;border:1.5px solid;border-image:linear-gradient(135deg,#333,#555,#333) 1;padding:24px 20px;width:100%;max-width:320px}
.wind-popup-title{font-size:12px;font-weight:600;letter-spacing:.1em;text-align:center;margin-bottom:14px}
.wind-speed-row,.wind-dir-row{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:14px}
.wind-opt{padding:10px 4px;border:1.5px solid var(--border);border-radius:4px;text-align:center;cursor:pointer;font-size:12px;font-weight:500;color:var(--text-dim);background:none;font-family:var(--font);min-height:44px;display:flex;align-items:center;justify-content:center}
.wind-opt.active{color:var(--silver);border-color:#555;background:rgba(208,208,200,.06)}
.wind-dir-section{display:none}.wind-dir-section.show{display:block}
.wind-done-btn{width:100%;padding:14px;border:1px solid #333;background:#0a0a08;color:var(--silver);font-weight:600;font-size:13px;font-family:var(--font);cursor:pointer;min-height:48px;margin-top:4px}

/* PRE-ROUND */
.preround-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.92);z-index:50;display:flex;flex-direction:column}
.preround-box{background:#050503;border:1.5px solid;border-image:linear-gradient(135deg,#6B4420,#D4845A,#6B4420) 1;padding:24px 20px;margin:auto 14px}
.preround-watermark{text-align:center;margin-bottom:8px;opacity:.3;font-size:9px;letter-spacing:.2em}
.preround-welcome{text-align:center;margin-bottom:16px}
.preround-welcome .silver{font-size:22px;line-height:1.3}.preround-welcome .copper{font-size:14px;font-style:italic;margin-top:5px;font-family:var(--serif)}
.preround-setup{display:flex;gap:8px;padding-bottom:14px;margin-bottom:14px;border-bottom:1px solid #111}
.preround-field{flex:1}
.preround-field label{display:block;font-size:10px;color:var(--text-dim);letter-spacing:.06em;margin-bottom:4px}
.preround-field input{background:none;border:1px solid var(--border);border-radius:4px;padding:8px 10px;color:var(--text);font-family:var(--font);font-size:14px;width:100%;outline:none;caret-color:var(--copper)}
.preround-field input:focus{border-color:var(--copper)}.preround-field input::placeholder{color:#444}
.preround-tagline{font-family:var(--serif);font-size:13px;font-style:italic;margin-bottom:14px}
.preround-disclaimer{font-size:9px;color:#444;text-align:center;margin-top:10px}

/* BAG */
.bag-header{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #111}
.bag-title{font-size:18px;font-weight:600}
.add-club-btn{padding:6px 12px;border:1px solid #2a4a2a;border-radius:4px;font-size:11px;color:var(--green);font-weight:600;cursor:pointer;background:none;font-family:var(--font);min-height:44px;display:flex;align-items:center}
.bag-list{flex:1;overflow-y:auto}
.club-row{display:flex;align-items:center;padding:10px 0;border-bottom:1px solid #111;gap:4px;min-height:48px}
.club-row.off{opacity:.4}
.club-row-name{font-size:14px;font-weight:600;min-width:60px;cursor:pointer}
.club-dist-area{display:flex;align-items:center;gap:4px;margin-left:auto;margin-right:4px}
.club-adj-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:4px;font-size:16px;color:var(--text-dim);cursor:pointer;background:none;font-family:var(--font)}
.club-adj-btn:active{background:#111}
.club-dist-num{font-size:20px;font-weight:600;min-width:44px;text-align:center;cursor:pointer}
.club-dist-yds{font-size:10px;color:var(--text-dim)}
.club-delete{background:none;border:none;cursor:pointer;padding:4px;font-size:10px;color:#444;font-family:var(--font);min-height:36px;min-width:36px;display:flex;align-items:center;justify-content:center}
.club-delete:active{color:var(--red)}
.toggle{width:40px;height:24px;border-radius:12px;position:relative;cursor:pointer;transition:background .2s;flex-shrink:0}
.toggle.on{background:#1a3a1a;border:1.5px solid #2a4a2a}.toggle.off{background:#1a1a18;border:1.5px solid #222}
.toggle-dot{width:18px;height:18px;border-radius:9px;position:absolute;top:2px;transition:left .2s}
.toggle.on .toggle-dot{left:18px;background:var(--green)}.toggle.off .toggle-dot{left:2px;background:#555}
.lefty-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-top:1px solid #111;font-size:14px;min-height:48px}

/* MENU */
.menu-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.97);z-index:100;display:flex;flex-direction:column;padding-top:env(safe-area-inset-top,0px)}
.menu-header{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border-bottom:1px solid #111;min-height:48px}
.menu-close{font-size:14px;color:var(--copper);font-weight:600;cursor:pointer;padding:8px;min-height:44px;display:flex;align-items:center;background:none;border:none;font-family:var(--font)}
.menu-list{flex:1;overflow-y:auto;padding:0 14px}
.menu-item{display:flex;align-items:center;gap:12px;padding:16px 0;border-bottom:1px solid #111;cursor:pointer;min-height:56px}
.menu-item:active{background:#0a0a08}
.menu-item.active-screen .menu-item-text{color:var(--gold)}
.menu-item-text{font-size:16px;font-weight:600;color:var(--text)}.menu-item-sub{font-size:11px;color:var(--text-dim);margin-top:2px}

/* SETTINGS */
.section-label{font-size:10px;color:var(--text-dim);letter-spacing:.08em;font-weight:600;padding:12px 0 6px}
.row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #111;min-height:48px}
.row-label{font-size:14px}.row-value{font-size:14px;font-weight:600}
.row-input{background:none;border:1px solid var(--border);border-radius:4px;padding:6px 10px;color:var(--text);font-family:var(--font);font-size:14px;text-align:right;outline:none;caret-color:var(--copper);width:160px}
.row-input:focus{border-color:var(--copper)}

/* HISTORY */
.shot-entry{padding:10px 4px;border-bottom:1px solid #0a0a08;cursor:pointer}.shot-entry:active{background:#0a0a08}
.shot-tag{display:inline-block;padding:2px 8px;border:1px solid;border-radius:3px;font-size:10px;font-weight:600}
.shot-tag.smart{color:var(--green);border-color:#2a4a2a}.shot-tag.hero{color:var(--copper);border-color:#3a2010}
.shot-detail{padding:10px;border:1px solid #111;border-radius:4px;margin-top:6px;font-size:12px;line-height:1.5;color:var(--text-dim);background:#050503}
.thumb-row{display:flex;gap:6px;margin-top:6px;align-items:center}
.thumb-btn{background:none;border:1px solid var(--border);border-radius:4px;padding:4px 10px;cursor:pointer;font-size:11px;font-weight:600;min-height:36px;font-family:var(--font);color:var(--text-dim)}
.thumb-btn.up.active{color:var(--green);border-color:#2a4a2a;background:rgba(93,170,104,.08)}
.thumb-btn.dn.active{color:var(--red);border-color:#3a1a1a;background:rgba(217,79,79,.08)}
.delete-shot-btn{background:none;border:none;cursor:pointer;padding:4px 8px;font-size:11px;color:#555;font-family:var(--font);min-height:36px}
.delete-shot-btn:active{color:var(--red)}

/* WHAT'S WORKING */
.insight-card{border:1.5px solid var(--border);border-radius:6px;padding:14px;margin-bottom:10px}
.insight-card.good{border-color:#2a4a2a}.insight-card.bad{border-color:#3a1a1a}
.insight-title{font-size:12px;font-weight:600;letter-spacing:.06em;margin-bottom:6px}
.insight-body{font-size:13px;line-height:1.5;color:var(--text-dim)}
.insight-stat{font-size:11px;margin-top:4px}

/* CONFESSIONAL / SHARE */
.stat-cards{display:flex;gap:8px;padding:12px 0}
.stat-card{flex:1;text-align:center;padding:12px 4px;border:1.5px solid var(--border);border-radius:6px}
.stat-num{font-size:28px;font-weight:600}.stat-label{font-size:10px;color:var(--text-dim);margin-top:3px}
.conf-box{border:1.5px solid var(--border);border-radius:6px;padding:16px;margin-bottom:12px}
.hero-moment{border:1.5px solid;border-image:linear-gradient(135deg,#3a2010,var(--copper),#3a2010) 1;padding:14px;margin-bottom:10px}
.roast-card{border:1.5px solid var(--border);border-radius:6px;padding:12px;margin-bottom:8px}
.roast-text{font-size:13px;line-height:1.5;color:var(--text);margin-bottom:8px}
.roast-actions{display:flex;gap:6px}
.roast-copy,.roast-share{padding:6px 12px;border:1px solid var(--border);border-radius:4px;font-size:11px;cursor:pointer;background:none;font-family:var(--font);min-height:36px;font-weight:500}
.roast-copy{color:var(--text-dim)}.roast-copy.copied{color:var(--green);border-color:#2a4a2a}
.roast-share{color:var(--green);border-color:#2a4a2a}

/* ONBOARDING */
.onboarding{position:absolute;top:0;left:0;right:0;bottom:0;background:var(--black);z-index:200;display:flex;flex-direction:column}
.ob-screen{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:0 24px}
.ob-dots{display:flex;gap:8px;justify-content:center;padding:14px 0}
.ob-dot{width:10px;height:10px;border-radius:5px}
.ob-dot.active{background:linear-gradient(135deg,#A06030,#E8A878,#D4845A)}.ob-dot.inactive{background:#222}
.ob-option{width:100%;padding:16px;border:1.5px solid var(--border);border-radius:6px;cursor:pointer;margin-bottom:8px;background:none;text-align:left;font-family:var(--font);display:flex;justify-content:space-between;align-items:center;min-height:56px}
.ob-option.selected{border-color:#2a4a2a;background:rgba(93,170,104,.06)}
.ob-option-label{font-size:18px;font-weight:600;color:var(--text-dimmer)}
.ob-option.selected .ob-option-label{color:var(--green)}
.ob-option-sub{font-size:11px;color:var(--text-dim);margin-top:2px}
.ob-radio{width:18px;height:18px;border-radius:9px;border:2px solid var(--text-dimmer);flex-shrink:0}
.ob-option.selected .ob-radio{border-color:var(--green);background:var(--green);box-shadow:inset 0 0 0 3px var(--black)}
.ob-input{width:100%;padding:14px 16px;border:1.5px solid #333;border-radius:4px;font-size:18px;color:var(--text);background:none;font-family:var(--font);outline:none;caret-color:var(--copper)}
.ob-input:focus{border-color:var(--copper)}.ob-input::placeholder{color:#444}

.policy-text{font-size:13px;line-height:1.7;color:var(--text-dim);white-space:pre-wrap;padding:12px 0}
#clipboard-toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%);background:#1a3a1a;border:1px solid #2a4a2a;color:var(--green);font-size:12px;font-weight:600;padding:10px 20px;border-radius:4px;z-index:300;opacity:0;pointer-events:none;transition:opacity .3s}
#clipboard-toast.show{opacity:1}
.home-bar{display:flex;justify-content:center;padding:6px 0 2px;padding-bottom:env(safe-area-inset-bottom,4px)}
.home-bar-line{width:100px;height:4px;background:#1a1a1a;border-radius:2px}
:focus-visible{outline:2px solid var(--gold);outline-offset:2px}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}}
