/* ============================================================================
   大灣區演講家 · AI 演講能力評估報告 — Report visuals
   勳章 / 三幕 / 雷達 / 四範疇 donut 等視覺語言（保留原品牌設計，token 化）。
   用於：即時評分頁（/try）與獨立報告（report_template，build 時內嵌）。
   ========================================================================== */
.rwrap{max-width:1010px;margin:0 auto;background:var(--bg);border:1px solid var(--line);
  border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow)}
.rwrap .block{padding:46px 56px}
.rwrap .block + .block{border-top:1px solid var(--line)}

/* —— INPUT CONSOLE（即時評分頁）—— */
.console{background:radial-gradient(125% 100% at 85% -10%,#5B3CC4 0%,#2E1A6B 45%,#170B33 100%);
  color:#fff;padding:34px 40px;position:relative;overflow:hidden}
.console-frame{position:absolute;inset:14px;border:1px solid rgba(228,194,92,.28);border-radius:7px;pointer-events:none}
.c-head{display:flex;align-items:center;gap:13px;position:relative;z-index:2}
.c-head .mic{width:27px;height:27px;flex:none}
.c-head .en{font-family:var(--font-disp);font-size:12.5px;letter-spacing:.34em;color:rgba(255,255,255,.6);text-transform:uppercase;margin-top:2px}
.c-title{font-size:26px;font-weight:600;margin-top:15px;position:relative;z-index:2}
.c-sub{color:var(--gold-pale);font-size:13.5px;margin-top:5px;position:relative;z-index:2;max-width:760px}
.fields{position:relative;z-index:2;margin-top:22px;display:grid;grid-template-columns:1fr 1.4fr 1fr 1fr;gap:13px}
.fld label{display:block;font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:var(--gold-bright);margin-bottom:6px}
.fld input,.fld select,.ta textarea{width:100%;background:rgba(255,255,255,.06);border:1px solid rgba(228,194,92,.3);
  color:#fff;border-radius:9px;padding:11px 13px;font-family:var(--font-sans);font-size:14px}
.fld input:focus,.fld select:focus,.ta textarea:focus{outline:none;border-color:var(--gold-bright)}
.fld select option{color:var(--ink)}
.ta{position:relative;z-index:2;margin-top:13px}
.ta label{display:block;font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:var(--gold-bright);margin-bottom:6px}
.ta textarea{min-height:150px;resize:vertical;line-height:1.8;font-size:14.5px}
.run{position:relative;z-index:2;margin-top:18px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.run .hint{font-size:12.5px;color:rgba(255,255,255,.58)}
.status{display:none;align-items:center;gap:12px;color:var(--gold-pale);font-size:14px;margin-top:14px;position:relative;z-index:2}
.status.show{display:flex}
.dots span{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--gold-bright);margin-right:5px;animation:bln 1.2s infinite}
.dots span:nth-child(2){animation-delay:.2s}.dots span:nth-child(3){animation-delay:.4s}
@keyframes bln{0%,80%,100%{opacity:.3}40%{opacity:1}}
.err{display:none;margin:18px 40px 0;background:var(--danger-bg);border:1px solid var(--danger);color:var(--danger-ink);
  padding:14px 18px;border-radius:10px;font-size:13.5px}
.err.show{display:block}

/* —— HERO（報告封面）—— */
#report{display:none}
.hero{position:relative;overflow:hidden;color:#fff;padding:52px 56px 40px;
  background:radial-gradient(125% 95% at 82% -12%,#5B3CC4 0%,#2E1A6B 44%,#170B33 100%)}
.hero::after{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(58% 46% at 50% -4%,rgba(228,194,92,.20),transparent 62%)}
.hero-frame{position:absolute;inset:16px;border:1px solid rgba(228,194,92,.30);border-radius:7px;pointer-events:none}
.hero-frame::before,.hero-frame::after{content:"";position:absolute;width:18px;height:18px;border:1.5px solid var(--gold-bright)}
.hero-frame::before{top:-1px;left:-1px;border-right:none;border-bottom:none}
.hero-frame::after{bottom:-1px;right:-1px;border-left:none;border-top:none}
.hero-top{display:flex;justify-content:space-between;align-items:center;position:relative;z-index:2;gap:18px;flex-wrap:wrap}
.brandline{display:flex;align-items:center;gap:13px}
.brandtxt .eyebrow{color:var(--gold-bright)}
.brandtxt .en{font-family:var(--font-disp);font-size:12.5px;letter-spacing:.34em;color:rgba(255,255,255,.6);text-transform:uppercase;margin-top:2px}
.round-badge{border:1px solid rgba(228,194,92,.55);color:var(--gold-bright);padding:6px 15px;border-radius:999px;font-size:12px;letter-spacing:.12em;white-space:nowrap}
.hero-main{position:relative;z-index:2;margin-top:30px;display:grid;grid-template-columns:1fr auto;gap:40px;align-items:center}
.h-kicker{font-size:12.5px;letter-spacing:.2em;color:rgba(255,255,255,.68)}
.h-person{font-size:56px;line-height:1.02;font-weight:600;margin:8px 0 12px;letter-spacing:.01em}
.h-title{font-size:23px;color:var(--gold-pale);font-weight:500}
.h-title .q{color:var(--gold-bright)}
.h-meta{margin-top:18px;display:flex;gap:9px;flex-wrap:wrap}
.chip{border:1px solid rgba(255,255,255,.22);border-radius:999px;padding:5px 14px;font-size:12.5px;letter-spacing:.05em;color:rgba(255,255,255,.85)}
.medal{width:236px;text-align:center;position:relative}
.medal-svg{width:212px;height:212px;display:block;margin:0 auto}
.medal-svg .track{fill:none;stroke:rgba(228,194,92,.16);stroke-width:7}
.medal-svg .prog{fill:none;stroke:var(--gold-bright);stroke-width:7;stroke-linecap:round;transform:rotate(-90deg);transform-origin:50% 50%;stroke-dasharray:var(--circ);stroke-dashoffset:var(--circ);transition:stroke-dashoffset 1.5s var(--ease) .25s}
.go .medal-svg .prog{stroke-dashoffset:var(--off)}
.medal-core{position:absolute;top:0;left:50%;transform:translateX(-50%);width:212px;height:212px;display:flex;flex-direction:column;align-items:center;justify-content:center}
.medal-core .lab{font-size:10px;letter-spacing:.26em;color:var(--gold-bright);text-transform:uppercase}
.medal-core .num{font-size:74px;line-height:.86;font-weight:700;color:#fff;margin-top:3px}
.medal-core .den{font-size:12px;color:rgba(255,255,255,.5);letter-spacing:.12em;margin-top:3px}
.stars{margin-top:6px;font-size:19px;letter-spacing:4px}
.stars i{color:rgba(228,194,92,.28);font-style:normal;opacity:0;transition:opacity .35s,color .35s}
.stars i.lit{color:var(--gold-bright)}.go .stars i{opacity:1}
.grade{font-size:12.5px;color:rgba(255,255,255,.8);margin-top:5px;letter-spacing:.08em}
.arche{margin-top:12px;display:inline-block;background:rgba(228,194,92,.13);border:1px solid rgba(228,194,92,.45);border-radius:9px;padding:8px 15px;color:var(--gold-pale);font-size:13px;font-weight:500}
.arche b{color:var(--gold-bright)}
.bench{position:relative;z-index:2;margin-top:30px;border-top:1px solid rgba(228,194,92,.24);padding-top:22px}
.bench-cap{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px}
.bench-cap .l{font-size:13.5px;color:rgba(255,255,255,.86)}.bench-cap .l b{color:var(--gold-bright)}
.bench-cap .r{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.5)}
.scale{position:relative;height:8px;border-radius:999px;background:linear-gradient(90deg,#3a2e6e 0%,#5a4aa0 35%,#9b7a2e 70%,#E4C25C 100%);box-shadow:inset 0 0 0 1px rgba(255,255,255,.06)}
.scale .line{position:absolute;top:-6px;bottom:-6px;width:2px;background:repeating-linear-gradient(180deg,var(--gold-bright) 0 4px,transparent 4px 8px)}
.scale .pin{position:absolute;top:50%;width:16px;height:16px;border-radius:50%;background:#fff;border:3px solid var(--gold);transform:translate(-50%,-50%) scale(0);transition:transform .6s var(--ease-spring) .9s;box-shadow:0 4px 12px rgba(0,0,0,.4)}
.go .scale .pin{transform:translate(-50%,-50%) scale(1)}
.scale-labels{display:flex;justify-content:space-between;margin-top:9px;font-size:10.5px;color:rgba(255,255,255,.5);letter-spacing:.04em}

/* —— Section heads inside report —— */
.rwrap .sec-title{font-size:27px}

/* —— style mix —— */
.mix-row{display:flex;align-items:center;gap:15px;margin:14px 0}
.mix-row .name{width:158px;font-size:14.5px;font-weight:500;flex:none}
.mix-row .name small{display:block;color:var(--muted);font-weight:400;font-size:11px;letter-spacing:.05em}
.mix-track{flex:1;height:11px;background:var(--line-soft);border-radius:999px;overflow:hidden}
.mix-fill{background:linear-gradient(90deg,var(--gold),var(--gold-bright))}
.mix-fill.alt{background:linear-gradient(90deg,var(--violet),var(--violet-pale));opacity:.9}
.mix-pct{width:48px;text-align:right;font-size:22px;font-weight:600;color:var(--royal)}
.reason{margin-top:18px;font-size:13.5px;color:var(--ink-mute);background:#FAF5E8;border-left:3px solid var(--gold);padding:13px 17px;border-radius:0 9px 9px 0}

/* —— score meters + viz —— */
.scorewrap{display:grid;grid-template-columns:1fr;gap:22px}
.meters{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.meter{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:20px 22px;box-shadow:var(--shadow-sm)}
.meter .mlab{font-size:13px;color:var(--muted);letter-spacing:.05em}
.meter .mscore{font-weight:700;color:var(--royal);margin:3px 0 13px}
.meter .mscore b{font-size:48px}.meter .mscore span{font-size:18px;color:var(--muted)}
.meter-track{height:8px;background:var(--line-soft);border-radius:999px;overflow:hidden}
.meter-fill{background:linear-gradient(90deg,var(--gold),var(--gold-bright))}
.meter .subi{margin-top:13px;font-size:12px;color:var(--muted);line-height:1.65}
.viz{display:block;margin-top:4px}
.radar-box{background:var(--card);border:1px solid var(--line);border-radius:15px;padding:20px;box-shadow:var(--shadow);max-width:580px;height:460px;margin:0 auto 22px}
.donuts{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.donut{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px 10px 14px;text-align:center;box-shadow:var(--shadow-sm)}
.donut svg{width:104px;height:104px}
.donut .d-track{fill:none;stroke:var(--line-soft);stroke-width:9}
.donut .d-prog{fill:none;stroke-width:9;stroke-linecap:round;transform:rotate(-90deg);transform-origin:50% 50%;stroke-dasharray:var(--circ);stroke-dashoffset:var(--circ);transition:stroke-dashoffset 1.3s var(--ease) .3s}
.go .donut .d-prog{stroke-dashoffset:var(--off)}
.donut .d-num{font-family:var(--font-disp);font-size:26px;font-weight:700;fill:var(--royal)}
.donut .d-name{font-size:13.5px;font-weight:500;margin-top:8px}
.donut .d-en{font-size:11px;color:var(--muted);letter-spacing:.05em}

/* —— three acts —— */
.act{position:relative;background:var(--card);border:1px solid var(--line);border-radius:15px;padding:23px;box-shadow:var(--shadow);transition:transform .25s ease}
.act:hover{transform:translateY(-3px)}
.act-no{font-family:var(--font-disp);font-size:13px;letter-spacing:.18em;color:var(--gold);text-transform:uppercase}
.act h4{font-size:18px;font-weight:600;color:var(--royal);margin:4px 0 12px}
.rate{display:inline-block;font-size:12px;font-weight:500;padding:3px 13px;border-radius:999px;letter-spacing:.1em;margin-bottom:12px}
.rate.高{background:var(--gold);color:#3a2c00}
.rate.中{background:var(--warn-bg);color:var(--warn-ink);border:1px solid var(--gold)}
.rate.低{background:var(--danger-bg);color:var(--danger-ink);border:1px solid var(--danger)}
.act p{font-size:13.5px;color:var(--ink-soft)}

/* —— pros / cons —— */
.pc{background:var(--card);border:1px solid var(--line);border-radius:15px;padding:23px 25px;box-shadow:var(--shadow)}
.pc h4{font-size:16px;margin-bottom:14px;font-weight:600;display:flex;align-items:center;gap:9px}
.pc.pro h4{color:var(--royal)}.pc.con h4{color:var(--danger)}
.pc h4 .tk{font-size:11px;font-weight:500;letter-spacing:.1em;padding:2px 10px;border-radius:999px}
.pc.pro h4 .tk{background:#F3E9CC;color:var(--warn-ink)}.pc.con h4 .tk{background:var(--danger-bg);color:var(--danger-ink)}
.pc-item{display:flex;gap:13px;padding:11px 0;border-top:1px solid var(--line);font-size:14px}
.pc-item:first-of-type{border-top:none}
.pc-num{font-family:var(--font-disp);font-weight:700;flex:none;width:22px;font-size:18px}
.pc.pro .pc-num{color:var(--gold)}.pc.con .pc-num{color:var(--danger)}

/* —— fixes + rewrite —— */
.fix{background:var(--card);border:1px solid var(--line);border-radius:15px;padding:20px 24px;margin-bottom:14px;box-shadow:var(--shadow)}
.fix-head{font-weight:600;color:var(--royal);font-size:15px;margin-bottom:13px;display:flex;align-items:center;gap:10px}
.fix-head .n{width:25px;height:25px;border-radius:50%;background:var(--royal);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;flex:none}
.fix-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.fix-cell .k{font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:var(--gold);font-weight:500;margin-bottom:6px}
.fix-cell .v{font-size:13.5px;color:var(--ink-soft)}
.rewrite{background:linear-gradient(165deg,#2a1857,#170b33);color:#fff;border-radius:17px;padding:30px 32px;box-shadow:var(--shadow);position:relative;overflow:hidden;margin-top:6px}
.rewrite::before{content:"\201C";position:absolute;top:-26px;right:22px;font-family:var(--font-disp);font-size:170px;color:rgba(228,194,92,.12)}
.rewrite .eyebrow{color:var(--gold-bright);margin-bottom:18px;display:block}
.rw-row{margin-bottom:18px;position:relative;z-index:2}
.rw-tag{font-size:11px;letter-spacing:.14em;text-transform:uppercase;margin-bottom:8px}
.rw-tag.b{color:rgba(255,255,255,.5)}.rw-tag.a{color:var(--gold-bright)}
.rw-text{font-family:var(--font-serif);font-size:16.5px;line-height:1.85}
.rw-row.before .rw-text{color:rgba(255,255,255,.6)}.rw-row.after .rw-text{color:#fff}
.rw-note{margin-top:7px;font-size:12.5px;color:var(--gold-pale);opacity:.85}

/* —— specialist + pitfalls —— */
.spec-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:13px}
.spec{background:var(--card);border:1px solid var(--line);border-radius:13px;padding:17px 12px;text-align:center;box-shadow:var(--shadow-sm)}
.spec .ring{position:relative;width:64px;height:64px;margin:0 auto 8px}
.spec .ring svg{width:64px;height:64px}
.spec .r-track{fill:none;stroke:var(--line-soft);stroke-width:6}
.spec .r-prog{fill:none;stroke:var(--gold);stroke-width:6;stroke-linecap:round;transform:rotate(-90deg);transform-origin:50% 50%;stroke-dasharray:var(--circ);stroke-dashoffset:var(--circ);transition:stroke-dashoffset 1s ease .35s}
.go .spec .r-prog{stroke-dashoffset:var(--off)}
.spec .sn{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-disp);font-weight:700;font-size:20px;color:var(--royal)}
.spec .sn small{font-size:11px;color:var(--muted)}
.spec .sl{font-size:12.5px;color:var(--ink-soft)}
.sp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.sp{display:flex;gap:12px;align-items:flex-start;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px 16px;box-shadow:var(--shadow-sm)}
.sp .ic{width:23px;height:23px;border-radius:7px;flex:none;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;margin-top:1px}
.sp.flag .ic{background:var(--danger-bg);color:var(--danger)}.sp.ok .ic{background:var(--success-bg);color:var(--success-ink)}
.sp .t{font-size:13.5px;font-weight:500}.sp .d{font-size:12px;color:var(--muted)}

/* —— CTA + report footer —— */
.cta{background:radial-gradient(125% 120% at 0% 0%,#5B3CC4,#2E1A6B 55%,#170B33);color:#fff;border-radius:19px;padding:36px 40px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.cta h3{font-family:var(--font-serif);font-size:24px;font-weight:600;position:relative;z-index:2}
.cta .lead{color:var(--gold-pale);margin-top:8px;font-size:14.5px;position:relative;z-index:2}
.cta-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:24px;position:relative;z-index:2}
.cstep{border:1px solid rgba(228,194,92,.3);border-radius:13px;padding:17px 19px}
.cstep .cn{color:var(--gold-bright);font-size:12px;letter-spacing:.18em;text-transform:uppercase}
.cstep .ct{font-weight:500;margin:6px 0;font-size:15px}.cstep .cd{font-size:12.5px;color:rgba(255,255,255,.74)}
.cta-proj{position:relative;z-index:2;margin-top:22px;background:rgba(228,194,92,.12);border:1px solid rgba(228,194,92,.4);border-radius:13px;padding:16px 20px;font-size:14px}
.cta-proj b{color:var(--gold-bright)}
.rfoot{padding:30px 56px 40px;background:#150A2C;color:rgba(255,255,255,.68);font-size:12.5px}
.rfoot .acts-row{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:18px}
.rfoot h5{color:var(--gold-bright);font-size:12px;letter-spacing:.16em;text-transform:uppercase;margin-bottom:11px;font-weight:500}
.rfoot p{margin-bottom:8px;line-height:1.7}.rfoot b{color:var(--gold-bright)}
.rfoot .fdemo{margin-top:18px;padding-top:16px;border-top:1px solid rgba(255,255,255,.12);color:var(--gold-pale);letter-spacing:.03em}

/* —— Responsive (report internals) —— */
@media (max-width:880px){
  .rwrap .block,.console,.hero,.rfoot{padding-left:24px;padding-right:24px}
  .fields{grid-template-columns:1fr 1fr}
  .hero-main{grid-template-columns:1fr;justify-items:center;text-align:center}
  .h-person{font-size:42px}.medal{margin-top:6px}
  .grid2,.grid3,.viz,.meters,.fix-grid,.cta-steps,.sp-grid{grid-template-columns:1fr}
  .donuts{grid-template-columns:1fr 1fr}.spec-grid{grid-template-columns:repeat(2,1fr)}.radar-box{height:420px}
}
@media (max-width:480px){
  .rwrap .block,.console,.hero,.rfoot{padding-left:16px;padding-right:16px}
  .fields,.donuts,.spec-grid{grid-template-columns:1fr}
  .radar-box{height:340px;max-width:none}
  .c-title{font-size:22px}.h-person{font-size:34px}.h-title{font-size:19px}
  .rwrap .sec-title{font-size:23px}.mix-row .name{width:120px}
  .medal,.medal-svg,.medal-core{width:180px}.medal-svg{height:180px}
}
@media print{
  .console,.err,.status,.rfoot .acts-row{display:none!important}
  .rwrap{border:none;box-shadow:none;background:#fff}
  .card,.act,.pc,.fix,.meter,.radar-box,.spec,.sp,.donut{box-shadow:none}
  .rwrap .block{padding:26px 30px;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .hero,.rewrite,.cta,.rfoot{-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .reveal{opacity:1!important;transform:none!important}
}
