#selectBtn { position:relative; z-index:2; pointer-events:auto; visibility:visible; opacity:1; transition:opacity .18s ease; }
.uploader.drag #selectBtn { opacity:0; pointer-events:none; }
.uploader { position:relative; }
.uploader.drag::after { z-index:3; }
.placeholder-anim{position:relative;display:inline-block;background:linear-gradient(145deg,#FFB326,#E47B00);color:rgba(40,26,7,.55);font-weight:500;border-radius:10px;min-width:84px;min-height:1.05em;padding:2px 10px;overflow:hidden;line-height:1.1;isolation:isolate;box-shadow:inset 0 0 0 1px rgba(0,0,0,.04),inset 0 2px 4px -2px rgba(0,0,0,.28)}
.placeholder-anim::before{content:"";position:absolute;inset:0;pointer-events:none;mix-blend-mode:overlay;background:radial-gradient(circle at 22% 35%,var(--shimmer-sheen-soft),transparent 65%),radial-gradient(circle at 78% 65%,var(--shimmer-sheen-soft),transparent 70%)}
.placeholder-anim::after{content:"";position:absolute;inset:0;background:linear-gradient(96deg,rgba(255,255,255,0) 0%,var(--shimmer-sheen) 55%,rgba(255,255,255,0) 100%);background-size:280% 100%;animation:shimmerScroll var(--shimmer-duration) linear infinite;mix-blend-mode:overlay;pointer-events:none}
.chip-loading,.badge-loading{background:none;position:relative}
.chip-loading::after,.badge-loading::after{content:"";display:inline-block;width:110px;height:16px;border-radius:10px;vertical-align:middle;background:repeating-linear-gradient(135deg,#F6A232 0 18px,#FDBB52 18px 36px);background-size:120px 120px;animation:barberFlow 1.5s linear infinite;box-shadow:inset 0 0 0 1px rgba(0,0,0,.12),0 2px 5px -2px rgba(0,0,0,.25)}
@keyframes shimmerScroll{0%{background-position:0 0}100%{background-position:200% 0}}
@media (prefers-reduced-motion:reduce){.placeholder-anim::after,.chip-loading::after,.badge-loading::after{animation-duration:3s}}
:root{
  --bg: #FFE7C9;
  --bg-grad: linear-gradient(135deg,#FFEAD2 0%,#FFE2A7 28%,#FFD493 55%,#FFC375 72%,#FFB85B 100%);
  --bg-noise: radial-gradient(circle at 15% 20%,rgba(255,255,255,.55),rgba(255,255,255,0) 60%),radial-gradient(circle at 85% 75%,rgba(255,184,91,.35),rgba(255,184,91,0) 65%);
  --grain: url("data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTUwIiBoZWlnaHQ9IjE1MCIgdmlld0JveD0iMCAwIDE1MCAxNTAiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PGZpbHRlciBpZD0iZyI+PGZlVHVyYnVsZW5jZSB0eXBlPSJmcmFjdGFsTm9pc2UiIGJhc2VGcmVxdWVuY3k9Ii4yIiBudW1PY3RhdmVzPSIxMCIgc3RpdGNoVGlsZXM9InN0aXRjaCIvPjwvZmlsdGVyPjxyZWN0IHdpZHRoPSIxNTAlIiBoZWlnaHQ9IjE1MCUiIGZpbHRlcj0idXJsKCNnKSIgZmlsbD0iI0ZGRiIvPjwvc3ZnPg==");
  --text: #281a07;
  --muted: #7A5721;
  --card: #FFF7EC;
  --card-alt: #FFF2DC;
  --line: #E2A448;
  --accent: #E46705;
  --accent-2: #FFB651;
  --accent-deep: #D34F00;
  --good: var(--accent);
  --shadow: 0 4px 18px -4px rgba(158,84,0,.16),0 2px 8px -2px rgba(158,84,0,.12);
  --shadow-hover: 0 6px 22px -4px rgba(158,84,0,.28),0 3px 10px -2px rgba(158,84,0,.18);
  --radius-lg: 30px;
  --radius-md: 18px;
  --gradient-accent: linear-gradient(90deg,#E46705 0%,#FFB651 55%,#FFC873 100%);
  --gradient-accent-deep: linear-gradient(90deg,#D34F00,#FF9D2E);
  --focus-ring: 0 0 0 3px #fff,0 0 0 5px rgba(228,103,5,.55);
  --shimmer-duration:1.15s;
  --shimmer-sheen:rgba(255,255,255,.68);
  --shimmer-sheen-soft:rgba(255,255,255,.12);
  --ease-out: cubic-bezier(.16,.8,.25,1);
}


body.minimal {
  --bg: #faf8f4;
  --card: #ffffff;
  --line: #e2e2e2;
  --accent: #1b62f1;
  --accent-2: #1b62f1;
  --good: #1b62f1;
  --text: #1d1f23;
  --muted: #5b626f;
  --shadow: 0 2px 4px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
  background: #fafafa;
  font-family: "Inter", system-ui, sans-serif;
}
body.minimal .topbar {background:#ffffffd9;backdrop-filter:saturate(1.1) blur(6px);box-shadow:0 1px 0 #e5e5e5; border-bottom: none;}
body.minimal .brand-logo {width:72px;height:72px;padding:0;border:none;box-shadow:none;background:transparent;border-radius:12px;}
body.minimal .brand-name {background:none;color:#111;font-family:'Manrope',Inter,sans-serif;font-weight:800;font-size:40px;letter-spacing:.5px;}
body.minimal .brand-name::after {display:none}
body.minimal .tag {background:#f3f4f6;border:1px solid #e3e4e6;box-shadow:none;color:#4b5563;font-weight:500}
body.minimal .card {background:#fff;border:1px solid #e5e7eb;border-radius:18px;box-shadow:0 2px 6px -2px rgba(0,0,0,.06),0 4px 16px -6px rgba(0,0,0,.04)}
body.minimal .uploader {border:1.5px dashed #c9ced6;border-radius:18px;min-height:300px}
body.minimal .uploader.drag {border-color: var(--accent); background:#f0f6ff;}
body.minimal .uploader.drag::after {color: var(--accent); background:rgba(255,255,255,.65)}
body.minimal .btn {border:1px solid #d1d5db;background:#fff;box-shadow:none;font-weight:600}
body.minimal .btn.primary {background:var(--accent);border-color:var(--accent);}
body.minimal .btn.primary:hover {filter:brightness(.95)}
body.minimal .sections section {background:#fff;border:1px solid #e5e7eb;box-shadow:none;padding:20px;border-radius:20px}
body.minimal .bullets li {background:#f8f9fa;border:1px solid #e2e6ea;box-shadow:none}
body.minimal .bullets li::before {background:var(--accent);box-shadow:none}
body.minimal .chip, body.minimal .badge {background:#eef1f5;border:1px solid #d5dae0;box-shadow:none;color:#374151;font-weight:500}
body.minimal .summary, body.minimal .mood-summary, body.minimal .style-intro, body.minimal .status-text {color:#374151}
body.minimal .placeholder-anim, body.minimal .chip-loading::after, body.minimal .badge-loading::after {animation:none;background:#eceff2;color:transparent;box-shadow:none}
body.minimal .spinner::before {border-top-color:var(--accent);border-right-color:var(--accent)}
body.minimal .spinner::after {border-bottom-color:rgba(27,98,241,.45);border-left-color:rgba(27,98,241,.15)}
body.minimal .sections section::before {display:none}
body.minimal .progress-badge {background:var(--accent)}
body.minimal .results {transition:none}
body.minimal .loader, body.minimal [class*="lb-"] {animation:none}
body.minimal .avatar {background:#f3f4f6;border:1px solid #e2e6ea;box-shadow:none}
body.minimal .footer {color:#6b7280}
body.minimal .brand {gap:16px}
body.minimal .brand-name {margin:0}
@media (max-width:760px){body.minimal .brand-logo{width:56px;height:56px}body.minimal .brand-name{font-size:34px}}

*{box-sizing:border-box}
html,body{margin:0;padding:0;min-height:100%;font-family:Inter,Fredoka,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;background:var(--bg-grad) fixed,var(--bg) fixed;color:var(--text);-webkit-font-smoothing:antialiased;background-repeat:no-repeat,no-repeat;background-size:cover,cover;background-position:center top,center;}
body::before{content:"";position:fixed;inset:0;pointer-events:none;background:var(--bg-noise);mix-blend-mode:overlay;opacity:.55}
body::after{content:"";position:fixed;inset:0;pointer-events:none;background:var(--grain);mix-blend-mode:overlay;opacity:.18;background-repeat:no-repeat;background-size:cover;background-position:center;}

.container{max-width:1040px;margin:0 auto;padding:0 24px}

.topbar{position:sticky;top:0;z-index:40;padding:10px 0;background:rgba(255,246,237,.75);backdrop-filter:blur(14px) saturate(1.4);border-bottom:1px solid rgba(228,103,5,.25);box-shadow:0 6px 22px -8px rgba(158,84,0,.28)}
.topbar-inner{display:flex;align-items:center;gap:18px;min-height:64px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.brand-logo{width:92px;height:92px;object-fit:contain;border-radius:26px;box-shadow:0 6px 14px -6px rgba(158,84,0,.35);background:linear-gradient(135deg,#fff,#FFEEDB);border:2px solid #FFB651;padding:10px;transition:transform .4s var(--ease-out), box-shadow .35s ease}
.brand:hover .brand-logo{transform:rotate(-6deg) scale(1.04);box-shadow:0 10px 26px -8px rgba(158,84,0,.4)}
.brand-name{margin:0;font-size:40px;line-height:.95;font-weight:700;letter-spacing:.2px;display:flex;align-items:flex-end;gap:4px;font-family:Fredoka,Inter,sans-serif}
.brand-chunk{display:inline-block;position:relative}
.brand-chunk.scan{font-weight:700;background:linear-gradient(90deg,#E46705,#FFB651 60%,#FFC873);-webkit-background-clip:text;background-clip:text;color:transparent}
.brand-chunk.my{font-weight:600;color:#313330;transform:translateY(3px);letter-spacing:.5px}
.brand-chunk.cat{font-weight:700;background:linear-gradient(90deg,#FFB651,#FFCF80);-webkit-background-clip:text;background-clip:text;color:transparent;letter-spacing:.5px}
.brand-name::after{display:none}
.tag{margin:0 0 0 auto;font-size:14px;font-weight:500;color:#6d4717;max-width:340px;line-height:1.35;position:relative;padding:11px 16px;border-radius:16px;background:linear-gradient(140deg,#FFF7EC,#FFE8C9);border:1px solid #E8B15A;box-shadow:0 4px 14px -6px rgba(158,84,0,.18);overflow:hidden}
.tag::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 75% 25%,rgba(255,205,140,.65),transparent 55%);mix-blend-mode:overlay;opacity:.6}
.tag::before{content:"";position:absolute;left:-8px;top:50%;transform:translateY(-50%);width:14px;height:14px;background:linear-gradient(145deg,#FFB326,#E47B00);border:1px solid #d88814;border-radius:4px;box-shadow:0 2px 6px -2px rgba(0,0,0,.25)}
@media (max-width:760px){
  .topbar-inner{flex-wrap:wrap;justify-content:flex-start;gap:10px}
  .tag{order:3;margin-left:0;width:100%;max-width:none}
  .brand-name{font-size:30px}
  .brand-logo{width:72px;height:72px}
}

.main{padding:0 0 32px}
.layout{display:grid;grid-template-columns:340px 1fr;gap:28px;align-items:start;padding-top:10px}
.left,.right{min-width:0}
.card{background:var(--card);border:1px solid rgba(226,164,72,.55);border-radius:var(--radius-md);box-shadow:var(--shadow);backdrop-filter:saturate(1.2);position:relative;overflow:hidden;transition:box-shadow .4s var(--ease-out), transform .45s var(--ease-out), border-color .4s ease}
.card::before{content:"";position:absolute;inset:0;background:linear-gradient(145deg,rgba(255,255,255,.6),rgba(255,255,255,0));mix-blend-mode:overlay;pointer-events:none;opacity:.6}
.card:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px);border-color:rgba(226,164,72,.8)}

.uploader{position:relative;display:grid;place-items:center;min-height:360px;overflow:hidden;background:linear-gradient(135deg,#FFF7EC,#FFEEDB 55%,#FFE4C2);}
.uploader .empty{text-align:center;padding:10px}
.uploader .hint{margin-top:8px;color:var(--muted)}
.uploader{position:relative}
.uploader .preview{position:absolute;inset:0;width:100%;height:100%;border-radius:inherit;object-fit:cover;display:block;opacity:0;transition:opacity .35s ease;box-shadow:0 8px 24px rgba(0,0,0,.12)}
.uploader .preview.show{opacity:1}
.uploader .preview.contain{object-fit:contain;background:#fff}
.uploader.has-image{border-style:solid}
.fit-toggle{position:absolute;top:8px;right:8px;z-index:2;background:rgba(0,0,0,.55);color:#fff;border:none;padding:6px 10px;font-size:11px;border-radius:999px;cursor:pointer;backdrop-filter:blur(4px);display:flex;align-items:center;gap:4px;line-height:1;font-weight:600;letter-spacing:.3px}
.fit-toggle:hover{background:rgba(0,0,0,.7)}
.fit-toggle:focus-visible{outline:2px solid #fff;outline-offset:2px}
.crop-ui{position:absolute;inset:0;z-index:3;pointer-events:none;font-size:12px;font-weight:500}
.crop-ui.active{pointer-events:auto}
.crop-area{position:absolute;box-shadow:0 0 0 100vmax rgba(0,0,0,.45);outline:2px solid #fff;border:1px solid rgba(0,0,0,.3);border-radius:12px;cursor:move;touch-action:none;user-select:none;overflow:hidden}
.crop-area::after{content:"";position:absolute;inset:0;background-image:linear-gradient(to right,rgba(255,255,255,.22) 1px,transparent 1px),linear-gradient(to bottom,rgba(255,255,255,.22) 1px,transparent 1px);background-size:calc(100%/3) calc(100%/3);mix-blend-mode:overlay;pointer-events:none}
.crop-area:focus-visible{outline:2px solid #FFB326}
.crop-ui .handle{position:absolute;width:18px;height:18px;background:#fff;border-radius:4px;border:1px solid #d78812;box-shadow:0 2px 6px -2px rgba(0,0,0,.4);display:grid;place-items:center;cursor:grab}
.crop-ui .handle:active{cursor:grabbing}
.crop-ui .handle::after{content:"";width:6px;height:6px;background:linear-gradient(145deg,#FFB326,#E47B00);border-radius:2px}
.crop-ui .handle.nw{top:-9px;left:-9px}
.crop-ui .handle.ne{top:-9px;right:-9px}
.crop-ui .handle.sw{bottom:-9px;left:-9px}
.crop-ui .handle.se{bottom:-9px;right:-9px}
.crop-controls{position:absolute;bottom:8px;left:50%;transform:translateX(-50%);display:flex;gap:6px;pointer-events:auto}
.btn.small{padding:4px 10px;font-size:11px;line-height:1}
@media (max-width:680px){
  .crop-ui .handle{width:14px;height:14px}
  .crop-ui .handle::after{width:5px;height:5px}
  .crop-controls{bottom:6px}
  .btn.small{padding:4px 8px;font-size:10px}
}
.uploader{border:2px dashed rgba(226,164,72,.8)}
.uploader.drag{border-color:var(--accent);background:linear-gradient(135deg,rgba(255,182,81,.35),rgba(255,165,38,.25));box-shadow:0 0 0 4px rgba(228,103,5,.2),0 0 0 1px var(--accent)}
.uploader.drag::after{content:"Drop image";position:absolute;inset:0;display:grid;place-items:center;font-size:20px;font-weight:700;letter-spacing:.5px;color:var(--accent);background:rgba(255,255,255,.6);backdrop-filter:blur(2px);border-radius:inherit;text-shadow:0 1px 2px #fff;z-index:3}
.uploader:hover{box-shadow:0 0 0 4px rgba(255,198,119,.35),0 0 0 1px rgba(228,103,5,.25)}

.controls .controls-inner{display:flex;flex-direction:column;gap:8px;padding:10px}
.w-100{width:100%}
.status-row{display:flex;align-items:center;gap:10px;color:var(--muted)}
.status-text{font-size:14px}

.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 16px;border-radius:12px;border:1px solid rgba(228,164,72,.6);background:#fff;color:var(--text);cursor:pointer;transition:transform .18s var(--ease-out), box-shadow .25s var(--ease-out), background .3s ease, border-color .3s ease;box-shadow:0 2px 4px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.06);font-weight:600;letter-spacing:.3px}
.btn:hover{transform:translateY(-2px);box-shadow:0 4px 10px -2px rgba(158,84,0,.25),0 2px 6px -2px rgba(158,84,0,.22)}
.btn:active{transform:translateY(0);transition-duration:.05s}
.btn:focus-visible{outline:none;box-shadow:var(--focus-ring)}
.btn:disabled{opacity:.6;pointer-events:none}
.btn.primary{background:var(--gradient-accent-deep);color:#fff;border:1px solid #D34F00;box-shadow:0 4px 14px -4px rgba(211,79,0,.45),0 2px 6px -1px rgba(211,79,0,.35)}
.btn.primary:hover{background:linear-gradient(90deg,#D34F00,#FFB651);box-shadow:0 6px 18px -6px rgba(211,79,0,.55),0 3px 10px -2px rgba(211,79,0,.4)}
.btn.primary:active{filter:brightness(.95)}
.btn.pulse{animation:pulseGlow 1.2s ease-in-out infinite}
@keyframes pulseGlow{0%,100%{box-shadow:0 0 0 0 rgba(255,138,0,.45)}50%{box-shadow:0 0 0 8px rgba(255,138,0,0)}}

.btn.download-ready{background:linear-gradient(120deg,#D34F00,#FFB651 40%,#FFC873 60%,#FF9D2E);background-size:260% 100%;animation:dlGradientShift 2.4s linear infinite, dlPulse 2.8s ease-in-out infinite;position:relative;isolation:isolate;border-color:#D34F00;color:#fff;box-shadow:0 6px 22px -6px rgba(211,79,0,.55),0 0 0 2px rgba(255,255,255,.3) inset,0 0 0 0 rgba(228,103,5,.45)}
.btn.download-ready:hover{animation-play-state:running;filter:brightness(1.05);box-shadow:0 10px 30px -8px rgba(211,79,0,.6),0 0 0 2px rgba(255,255,255,.4) inset}
.btn.download-ready:active{transform:translateY(0) scale(.98)}
.btn.download-ready::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(255,255,255,0) 0%,rgba(255,255,255,.55) 45%,rgba(255,255,255,0) 70%);mix-blend-mode:overlay;animation:dlSheen 3.2s ease-in-out infinite;pointer-events:none;border-radius:inherit}
.btn.download-ready::before{content:"";position:absolute;top:8px;left:10%;width:6px;height:6px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#fff,rgba(255,255,255,0));filter:drop-shadow(0 0 4px rgba(255,255,255,.85));animation:dlSpark 2.4s linear infinite;mix-blend-mode:screen}
@keyframes dlGradientShift{0%{background-position:0 0}100%{background-position:200% 0}}
@keyframes dlPulse{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-2px) scale(1.02)}}
@keyframes dlSheen{0%{opacity:.25;transform:translateX(-60%)}45%{opacity:.9}60%{opacity:0}100%{opacity:0;transform:translateX(60%)} }
@keyframes dlSpark{0%{transform:translate(0,0) scale(.9);opacity:0}10%{opacity:1}40%{transform:translate(260%,40%) scale(1.1);opacity:1}60%{opacity:0}100%{opacity:0;transform:translate(360%,80%) scale(.5)}}
@media (prefers-reduced-motion:reduce){.btn.download-ready{animation:none}.btn.download-ready::after,.btn.download-ready::before{animation:none}}

.spinner{width:20px;height:20px;position:relative;display:inline-block}
.spinner::before,.spinner::after{content:"";position:absolute;inset:0;border-radius:50%;border:3px solid transparent}
.spinner::before{border-top-color:#E05E00;border-right-color:#FFB326;border-left-color:#FFB326;filter:drop-shadow(0 0 4px rgba(224,94,0,.45));animation:spin .9s cubic-bezier(.65,.05,.36,1) infinite}
.spinner::after{border-bottom-color:rgba(255,179,38,.6);border-left-color:rgba(255,179,38,.2);animation:spinReverse 1.8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes spinReverse{to{transform:rotate(-360deg)}}



.results{padding:10px}
.results{opacity:0;transform:translateY(6px);transition:opacity .45s ease, transform .45s ease}
.results.visible{opacity:1;transform:translateY(0)}
.post-head{display:flex;gap:12px;align-items:center}
.avatar{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;background:var(--card);border:1px solid var(--line);box-shadow:var(--shadow);font-size:22px}
.meta h2{margin:0 0 4px 0}
.top-loader{margin-top:6px;--loader-h:26px;width:100%;max-width:420px;display:block}
.meta.loading #topMeta{visibility:hidden;position:absolute;pointer-events:none}
.meta.loading .top-loader{display:block}
.meta .top-loader{display:none}
.chips{display:flex;gap:8px;flex-wrap:wrap}
.chip{background:linear-gradient(145deg,#FFB326,#E47B00);border:1px solid #b45d00;padding:6px 12px;border-radius:999px;font-size:12px;color:#281a07;font-weight:600;position:relative;overflow:hidden;box-shadow:inset 0 0 0 1px rgba(255,255,255,.35),0 2px 4px -2px rgba(0,0,0,.25)}
.chip.chip-loading{opacity:.95}

.summary{color:#3b4660;margin-top:12px}
.sections{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:28px;margin-top:24px}
.sections section{background:linear-gradient(165deg,#FFF7EC,#FFE8C9 55%,#FFE0B3);border:1px solid #E6B562;border-radius:24px;padding:24px 24px 16px;box-shadow:0 10px 34px -8px rgba(158,84,0,.25);position:relative;overflow:hidden;align-self:start;transition:box-shadow .4s var(--ease-out), transform .45s var(--ease-out)}
.sections section::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 85% 12%,rgba(255,205,140,.5),transparent 60%),radial-gradient(circle at 18% 18%,rgba(255,255,255,.75),transparent 55%);pointer-events:none;mix-blend-mode:overlay;opacity:.85}
.sections section:hover{box-shadow:0 16px 42px -10px rgba(158,84,0,.32);transform:translateY(-3px)}
.sections section.span-2{grid-column:span 2}
.bullets{margin:0;padding:0;list-style:none}
.bullets li{display:flex;gap:10px;align-items:flex-start;margin:12px 0;padding:12px 14px;border:1px solid #E4B25E;border-radius:16px;background:linear-gradient(140deg,#FFF9F0,#FFE8C9);backdrop-filter:blur(3px);position:relative;box-shadow:0 4px 14px -4px rgba(158,84,0,.22);transition:background .35s ease,border-color .4s ease,box-shadow .4s ease}
.bullets li::before{content:"";width:10px;height:10px;border-radius:50%;background:var(--accent);margin-top:7px;flex-shrink:0;box-shadow:0 0 0 4px rgba(228,103,5,.28);transition:transform .45s var(--ease-out)}
.bullets li:hover{background:linear-gradient(140deg,#FFFDF8,#FFEFD9);box-shadow:0 6px 20px -6px rgba(158,84,0,.28)}
.bullets li:hover::before{transform:scale(1.2)}
.bullets li .lead{font-weight:600;color:#4a3414}
.bullets li .detail{color:#60461b;font-weight:450}
.collapsed{display:none}
.show-more-btn{background:#fff;border:1px solid #d78812;border-radius:10px;padding:6px 10px;font-size:12px;cursor:pointer;margin-top:4px;box-shadow:0 2px 6px -2px rgba(0,0,0,.2)}
.show-more-btn:hover{background:#FFE8BD}
.progress-badge{font-size:11px;background:#E05E00;color:#fff;padding:2px 6px;border-radius:999px;margin-left:6px;font-weight:600}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);clip-path:inset(50%);border:0;white-space:nowrap}
.disclaimer{color:#71809a;font-size:13px;margin-top:10px}

.bullets li.incoming{opacity:0;transform:translateY(6px) scale(.95);background:linear-gradient(135deg,#F9C263,#F6A232);border-style:solid}
.bullets li.incoming.enter{opacity:1;transform:translateY(0) scale(1);transition:opacity .55s ease, transform .55s cubic-bezier(.22,.8,.32,1), background .8s ease, border-color .6s ease}
.bullets li.incoming.enter{background:linear-gradient(135deg,#FFF1CF,#F9C970);border-color:#d78812}

.mood-block{display:flex;flex-direction:column;gap:2px}
.mood-line{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.badge{display:inline-flex;align-items:center;gap:4px;background:linear-gradient(145deg,#FFC873,#FFB651);border:1px solid #DA8F2D;padding:4px 11px;border-radius:999px;font-size:12px;color:#2b1907;font-weight:600;letter-spacing:.4px;position:relative;overflow:hidden;box-shadow:inset 0 0 0 1px rgba(255,255,255,.5),0 2px 4px -2px rgba(0,0,0,.25)}
.badge.badge-loading{opacity:.97}
.paw-rating{font-size:15px;line-height:1;display:inline-flex;gap:1px}
.paw-rating .paw{filter:grayscale(1) opacity(.4);transition:filter .3s}
.paw-rating .paw.full{filter:none;color:var(--accent)}
.mood-summary{margin:2px 0 0 0;color:#3b4660;font-size:12px}
.style-intro{font-size:14px;color:#3b4660;margin-bottom:4px}

.section-wrap[data-section="mood"]{padding-top:6px}
.section-wrap[data-section="mood"] .mood-top-title{
  display:inline-flex;
  align-items:flex-end;
  gap:10px;
  font-family:'Barlow Condensed', 'Barlow Condensed Fallback', Fredoka, Inter, sans-serif;
  font-weight:200; 
  letter-spacing:.5px;
  font-size:clamp(40px,5.2vw,70px);
  line-height:.82;
  margin:0 0 6px;
  position:relative;
  white-space:nowrap;
  color:#E46705;
  text-shadow:0 2px 4px rgba(0,0,0,.18);
  z-index:1000;
}
.section-wrap[data-section="mood"] .mood-top-title .vibe-icon{width:52px;height:auto;display:block;filter:drop-shadow(0 3px 5px rgba(158,84,0,.35)) brightness(1.05);transform:translateY(6px);}
.section-wrap[data-section="mood"] .mood-top-title .vibe-text{position:relative;display:inline-block;min-width:1ch;font-weight:200}
.section-wrap[data-section="mood"] .mood-top-title .vibe-text.gradient{background:linear-gradient(92deg,#E46705,#FFB651 55%,#FFC873);background-size:250% 100%;background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;color:transparent;filter:drop-shadow(0 4px 8px rgba(211,79,0,.2));text-shadow:none;font-weight:200}
.section-wrap[data-section="mood"] .mood-top-title .vibe-text::after{content:"";position:absolute;left:0;bottom:4px;height:10px;width:100%;background:linear-gradient(90deg,rgba(255,255,255,.65),rgba(255,255,255,0));mix-blend-mode:overlay;pointer-events:none;opacity:.65}
.section-wrap[data-section="mood"].loading .mood-top-title .vibe-text.gradient{animation:vibeSweep 4.2s linear infinite}
.section-wrap[data-section="mood"].ready .mood-top-title .vibe-text.gradient{animation:none;background-position:40% 0}
@keyframes vibeSweep{0%{background-position:0 0}50%{background-position:120% 0}100%{background-position:240% 0}}
@media (prefers-reduced-motion:reduce){.section-wrap[data-section="mood"].loading .mood-top-title{animation:none}}
.no-gradient .section-wrap[data-section="mood"] .mood-top-title{background:none;-webkit-text-fill-color:currentColor;color:var(--accent)}
body.minimal .section-wrap[data-section="mood"] .mood-top-title{background:linear-gradient(92deg,var(--accent),var(--accent));-webkit-text-fill-color:var(--accent);color:var(--accent)}

article.card.results.hidden .mood-top-title { position:static; }

.sections section[data-section="mood"].feature{grid-column:span 2;display:grid;place-items:center;padding:30px 40px 28px;background:linear-gradient(135deg,#FFE7C2,#FFD08A 45%,#FFB85A);position:relative;border:1px solid #d1861d}
.sections section[data-section="mood"].feature::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 30%,rgba(255,255,255,.85),transparent 62%),radial-gradient(circle at 78% 70%,rgba(255,190,90,.6),transparent 70%);mix-blend-mode:overlay;pointer-events:none}
.sections section[data-section="mood"].feature .section-title{margin:0 0 14px 0;font-size:15px;letter-spacing:1.6px;font-weight:800;text-transform:uppercase;color:#a25e00;text-align:center}
.sections section[data-section="mood"].feature .mood-block{align-items:center;max-width:580px;text-align:center}
.sections section[data-section="mood"].feature .mood-line{justify-content:center;font-size:16px}
.sections section[data-section="mood"].feature .badge{font-size:15px;padding:7px 18px}
.sections section[data-section="mood"].feature .paw-rating{font-size:22px;margin-top:6px}
.sections section[data-section="mood"].feature .mood-summary{font-size:15px;line-height:1.45;margin-top:14px;max-width:600px}
@media (max-width:960px){.sections section[data-section="mood"].feature{grid-column:span 1;padding:26px 28px}}

#disclaimer.placeholder-anim{animation:none;background:none;color:#71809a;padding:0}

.footer {width:100%;text-align:center;padding:24px 0 18px;font-size:12px;color:rgba(40,26,7,.55);background:none;letter-spacing:.4px}
.footer a{opacity:.72;transition:opacity .3s ease,color .3s ease}
.footer a:hover{opacity:1;color:var(--accent)}

.section-wrap{position:relative;min-height:110px}
.section-wrap.loading .section-body{display:none}
.section-wrap .section-loader{margin:10px 0 2px}
.section-wrap.ready .section-loader{display:none}
.section-wrap.ready .section-body{display:block;animation:fadeIn .4s ease}
.section-wrap{content-visibility:auto;contain:content}
.section-wrap[data-section="mood"]{content-visibility:visible;contain:initial}
@keyframes fadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}

.loader{display:inline-grid;--loader-h:18px}
.loader:before,.loader:after{content:"";height:var(--loader-h);aspect-ratio:5;--c:#F6A232 90deg,#0000 0;background:
 conic-gradient(from 135deg at top,var(--c)),
 conic-gradient(from -45deg at bottom,var(--c)) 12.5% 100%;
background-size:20% 50%;background-repeat:repeat-x;clip-path:inset(0 100% 0 0);animation:l9 1s infinite linear;border-radius:999px}
.loader:after{scale:-1 1}
@keyframes l9{90%,to{clip-path:inset(0)}}

.chip-loading,.badge-loading{position:relative}
.chip-loading::after,.badge-loading::after{content:"";display:inline-block;vertical-align:middle;height:18px;aspect-ratio:5;--c:#F6A232 90deg,#0000 0;background:conic-gradient(from 135deg at top,var(--c)),conic-gradient(from -45deg at bottom,var(--c)) 12.5% 100%;background-size:20% 50%;background-repeat:repeat-x;clip-path:inset(0 100% 0 0);animation:l9 1s linear infinite;border-radius:999px;margin-left:4px}
.chip-loading span,.badge-loading span{display:none}

.loader-gallery{background:linear-gradient(160deg,#FFF1CF,#F9C970);border:1px solid #d78812}
.loader-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.loader-list li{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid #d78812;border-radius:14px;background:linear-gradient(135deg,#FFF7E7,#FFD186);position:relative;overflow:hidden}
.loader-num{flex:0 0 30px;height:30px;display:grid;place-items:center;font-size:13px;font-weight:700;border-radius:8px;background:linear-gradient(145deg,#FFB326,#E47B00);color:#281a07;box-shadow:0 2px 4px -1px rgba(0,0,0,.25)}
.lb{--h:10px;--r:8px;position:relative;height:var(--h);border-radius:var(--r);flex:1;overflow:hidden;background:linear-gradient(90deg,#FAD074,#F6A232);box-shadow:inset 0 0 0 1px rgba(0,0,0,.12),0 4px 10px -4px rgba(0,0,0,.25)}
.lb-1::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(255,255,255,0) 0%,rgba(255,255,255,.75) 45%,rgba(255,255,255,0) 90%);animation:lbSweep1 1.15s linear infinite}
@keyframes lbSweep1{0%{transform:translateX(-60%)}100%{transform:translateX(60%)}}
.lb-2::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(255,255,255,0) 10%,rgba(255,255,255,.7) 55%,rgba(255,255,255,0) 95%);animation:lbSweep2 1.15s linear infinite}
@keyframes lbSweep2{0%{transform:translateX(60%)}100%{transform:translateX(-60%)}}
.lb-3{background:linear-gradient(90deg,#FDBB52,#F7931E);animation:lbPulse 1.4s ease-in-out infinite}
@keyframes lbPulse{0%,100%{filter:brightness(1)}50%{filter:brightness(1.35)}}
.lb-4{background:linear-gradient(90deg,#F6A232,#FDD982,#F6A232);background-size:220% 100%;animation:lbSlide 1.6s ease-in-out infinite}
@keyframes lbSlide{0%,100%{background-position:0 0}50%{background-position:100% 0}}
.lb-5{background:repeating-linear-gradient(135deg,#F6A232 0 14px,#FDBB52 14px 28px);animation:lbStripes 1.2s linear infinite}
@keyframes lbStripes{0%{background-position:0 0}100%{background-position:28px 0}}

.placeholder-anim.lb-5-smooth{--stripe-a:#F8AB38;--stripe-b:#FDBB52;background:linear-gradient(135deg,var(--stripe-a) 25%,var(--stripe-b) 25% 50%,var(--stripe-a) 50% 75%,var(--stripe-b) 75%);background-size:56px 56px;animation:stripesSmooth 1.4s linear infinite;color:rgba(40,26,7,.65);font-weight:600;letter-spacing:.3px}
.placeholder-anim.lb-5-smooth::before,.placeholder-anim.lb-5-smooth::after{content:none;animation:none}
@keyframes stripesSmooth{0%{background-position:0 0}100%{background-position:56px 0}}
@media (prefers-reduced-motion:reduce){.placeholder-anim.lb-5-smooth{animation-duration:4s;filter:brightness(.95)}}
.lb-6::before,.lb-6::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(255,255,255,0) 0%,rgba(255,255,255,.75) 50%,rgba(255,255,255,0) 90%);animation:lbSweep1 1.25s linear infinite}
.lb-6::after{animation-delay:.55s}
.lb-7::before{content:"";position:absolute;inset:0;background:var(--gradient-accent);transform-origin:left;animation:lbGrow 1.4s ease-in-out infinite}
@keyframes lbGrow{0%{transform:scaleX(.08)}50%{transform:scaleX(1)}100%{transform:scaleX(.08)}}
.lb-8{--h:14px;border-radius:14px;animation:lbBlob 2.2s ease-in-out infinite;background:linear-gradient(90deg,#FDBB52,#F6A232)}
@keyframes lbBlob{0%,100%{border-radius:14px}50%{border-radius:24px}}
.lb-9{display:grid;grid-template-columns:repeat(6,1fr);gap:4px;background:none}
.lb-9::before,.lb-9::after{display:none}
.lb-9 span{background:linear-gradient(145deg,#FFB326,#E47B00);border-radius:6px;animation:lbStep 1s linear infinite}
.lb-9 span:nth-child(2){animation-delay:.1s}.lb-9 span:nth-child(3){animation-delay:.2s}.lb-9 span:nth-child(4){animation-delay:.3s}.lb-9 span:nth-child(5){animation-delay:.4s}.lb-9 span:nth-child(6){animation-delay:.5s}
@keyframes lbStep{0%,60%,100%{opacity:.3}30%{opacity:1}}
.lb-10{background:none}
.lb-10::before{content:"";position:absolute;inset:0;display:flex;align-items:center;justify-content:space-around}
.lb-10::before{background:radial-gradient(circle at 10% 50%,#F6A232 0 4px,transparent 5px),radial-gradient(circle at 30% 50%,#F6A232 0 4px,transparent 5px),radial-gradient(circle at 50% 50%,#F6A232 0 4px,transparent 5px),radial-gradient(circle at 70% 50%,#F6A232 0 4px,transparent 5px),radial-gradient(circle at 90% 50%,#F6A232 0 4px,transparent 5px);animation:lbDots 1.1s ease-in-out infinite}
@keyframes lbDots{0%,100%{filter:opacity(.35)}50%{filter:opacity(1)}}
.lb-11{background:linear-gradient(135deg,#F6A232,#FFCF7A);background-size:200% 200%;animation:lbDiag 1.8s ease infinite}
@keyframes lbDiag{0%{background-position:0 0}50%{background-position:100% 100%}100%{background-position:0 0}}
.lb-12{background:#F6A232;box-shadow:inset 0 0 0 1px rgba(0,0,0,.15);position:relative}
.lb-12::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,0),rgba(255,255,255,.95),rgba(255,255,255,0));mix-blend-mode:overlay;animation:lbEdge 1.4s ease-in-out infinite}
@keyframes lbEdge{0%,100%{opacity:0;transform:translateX(-40%)}50%{opacity:1;transform:translateX(40%)}}
.lb-13{background:#F6A232;animation:lbGlow 2.1s ease-in-out infinite}
@keyframes lbGlow{0%,100%{box-shadow:inset 0 0 0 0 rgba(255,255,255,.4)}50%{box-shadow:inset 0 0 0 8px rgba(255,255,255,.15)}}
.lb-14{background:repeating-linear-gradient(90deg,#F6A232 0 18px,#FDBB52 18px 36px);position:relative}
.lb-14::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,#FFCF7A,#F6A232);transform-origin:left;animation:lbGrow 1.6s ease-in-out infinite}
.lb-15{background:#F6A232;transform-origin:left;animation:lbElastic 1.5s cubic-bezier(.68,-0.4,.27,1.4) infinite}
@keyframes lbElastic{0%,100%{transform:scaleX(.15)}45%{transform:scaleX(1)}}
.lb-16{background:linear-gradient(90deg,#F6A232,#F6A232);position:relative}
.lb-16::after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(180deg,rgba(255,255,255,.75) 0 3px,rgba(255,255,255,0) 3px 6px);animation:lbSweep1 1.1s linear infinite;mix-blend-mode:overlay}
.lb-17{background:#F6A232;position:relative}
.lb-17::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,#FFCF7A,#F6A232,#FFCF7A);background-size:220% 100%;animation:lbSlide 1.4s ease-in-out infinite;mix-blend-mode:overlay}
.lb-18{background:linear-gradient(90deg,#FAD074,#F6A232);position:relative}
.lb-18::after{content:"";position:absolute;top:50%;left:0;width:18%;height:60%;background:linear-gradient(145deg,#FFB326,#E47B00);border-radius:inherit;animation:lbRunner 1.3s cubic-bezier(.65,.05,.36,1) infinite}
@keyframes lbRunner{0%{transform:translateX(0) translateY(-50%) scaleX(.4)}50%{transform:translateX(460%) translateY(-50%) scaleX(.9)}100%{transform:translateX(0) translateY(-50%) scaleX(.4)}}
.lb-19{background:#F6A232;position:relative;overflow:visible}
.lb-19::after{content:"";position:absolute;left:0;top:0;bottom:0;width:22%;background:linear-gradient(90deg,#FFCF7A,#F6A232);border-radius:inherit;animation:lbPing 1.2s ease-in-out infinite}
@keyframes lbPing{0%{transform:translateX(0)}60%{transform:translateX(350%)}100%{transform:translateX(0)}}
.lb-20{background:#F6A232;position:relative;overflow:hidden}
.lb-20::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,#FFCF7A,#F6A232);transform-origin:left;animation:lbGrow 1.8s ease-in-out infinite}
.lb-20::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(255,255,255,0) 10%,rgba(255,255,255,.85) 50%,rgba(255,255,255,0) 90%);animation:lbSweep2 1.15s linear infinite}

.lb-9{counter-reset:seg}
.lb-9::before{display:none}
.lb-9 span{display:block;height:100%}




@media (max-width: 960px){.uploader{min-height:300px}.layout{grid-template-columns:1fr;gap:22px}.sections{grid-template-columns:1fr;gap:22px}.brand-name{font-size:34px}.brand-logo{width:78px;height:78px}}
@media (max-width: 680px){
  .tag{padding:10px 14px;font-size:13px}
  .uploader{min-height:240px}
  .sections section{padding:18px 18px 10px}
  .bullets li{margin:10px 0;padding:10px 12px}
  .container{padding:0 18px}
}

.hidden{display:none}
md-elevated-card{display:block;background:rgba(16,20,44,.78);border:1px solid var(--line);border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,.35);padding:0}

.helper-banner{position:relative;display:flex;align-items:center;gap:8px;background:#1c2430;color:#fff;font-size:13px;padding:10px 14px;border-radius:14px;border:1px solid #2b3544;margin-top:4px;animation:slideIn .35s ease;box-shadow:0 6px 20px -4px rgba(0,0,0,.35)}
.helper-banner strong{font-weight:600;color:#fff}
.helper-banner .close{margin-left:auto;cursor:pointer;background:#2b3544;border:none;color:#fff;width:24px;height:24px;border-radius:8px;font-size:16px;line-height:1;padding:0;display:grid;place-items:center}
.helper-banner .close:hover{background:#394559}
.helper-banner .arrow{position:absolute;top:-12px;left:70px;width:0;height:0;border-left:10px solid transparent;border-right:10px solid transparent;border-bottom:12px solid #1c2430;filter:drop-shadow(0 -3px 2px rgba(0,0,0,.25))}
.helper-banner.closing{animation:fadeOut .25s forwards}
@keyframes slideIn{from{transform:translateY(-6px);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes fadeOut{to{transform:translateY(-4px);opacity:0}}

.section-wrap[data-section="mood"] .mood-top-title{font-size:clamp(28px,3.8vw,46px);gap:8px;font-weight:400;line-height:.9;margin:0 0 4px}
.section-wrap[data-section="mood"] .mood-top-title .vibe-text.gradient{background-size:100% 100%;filter:drop-shadow(0 2px 4px rgba(211,79,0,.2))}
.section-wrap[data-section="mood"] .mood-top-title .vibe-text::after{bottom:2px;height:6px;opacity:.55}
.section-wrap[data-section="mood"].loading .mood-top-title .vibe-text.gradient{animation:none!important}
