/* remove-mobile-spark-icon-v11 */
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Arial,sans-serif;color:var(--text);background:var(--body-bg);transition:background .25s,color .25s}a{color:inherit;text-decoration:none}img{max-width:100%}:root{--text:#111827;--muted:#647084;--body-bg:#dfe3e8;--surface:#ffffff;--surface2:#f6f8fb;--card:rgba(255,255,255,.92);--border:#e6eaf0;--shadow:0 24px 70px rgba(15,23,42,.13);--accent:#111318;--accentText:#ffffff;--glass:rgba(255,255,255,.82)}html.dark,html[data-theme="dark"]{--text:#eef2f7;--muted:#aeb8c9;--body-bg:#0f172a;--surface:#111827;--surface2:#1f2937;--card:rgba(17,24,39,.92);--border:#334155;--shadow:0 26px 75px rgba(0,0,0,.42);--accent:#f8fafc;--accentText:#0f172a;--glass:rgba(15,23,42,.82)}html.dark body,html[data-theme="dark"] body{color:var(--text)}.site-header{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:14px 7vw;background:var(--glass);backdrop-filter:blur(18px);border-bottom:1px solid var(--border);box-shadow:0 10px 30px rgba(0,0,0,.06)}.brand{display:flex;align-items:center;gap:12px;font-weight:950;letter-spacing:-.02em}.brand img{width:42px;height:42px;border-radius:50%;object-fit:contain;object-position:center;background:#fff;box-shadow:0 4px 14px #0002;padding:3px}.nav{display:flex;align-items:center;gap:14px;font-weight:850}.nav a{opacity:.95}.nav a:hover{opacity:1}.nav form{margin:0}.nav button{border:0;background:transparent;color:var(--text);font-weight:850;cursor:pointer}.nav-btn{background:var(--accent);color:var(--accentText)!important;padding:10px 17px;border-radius:999px}.theme-toggle{display:inline-grid!important;place-items:center;width:42px;height:42px;border-radius:999px!important;border:1px solid var(--border)!important;background:var(--surface2)!important;color:var(--text)!important;font-size:18px!important;padding:0!important;box-shadow:0 8px 22px rgba(0,0,0,.08)}main{min-height:calc(100vh - 155px);padding:42px 0 0}.site-footer{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:26px 7vw;background:var(--glass);backdrop-filter:blur(16px);border-top:1px solid var(--border)}.site-footer b{display:block}.site-footer span{color:var(--muted)}.footer-links{display:flex;gap:16px;font-weight:850}.alert{max-width:1180px;margin:18px auto 0;padding:13px 16px;border-radius:16px;border:1px solid var(--border);background:var(--surface)}.success{background:#ddf9e8;color:#14532d}.error{background:#ffe2e2;color:#7f1d1d}.glass-card{background:var(--card);backdrop-filter:blur(18px);border:1px solid var(--border);box-shadow:var(--shadow)}.desktop-home{width:min(1240px,92vw);margin:0 auto 32px;display:grid;grid-template-columns:1.08fr .92fr;gap:32px;align-items:stretch}.hero-left,.hero-right{border-radius:34px;padding:44px;overflow:hidden}.top-kicker{display:inline-flex;align-items:center;width:max-content;background:var(--accent);color:var(--accentText);border-radius:999px;padding:9px 14px;font-weight:950;font-size:12px;letter-spacing:.02em;text-transform:uppercase}.top-kicker.soft{background:var(--surface2);color:var(--text);border:1px solid var(--border)}.hero-logo{display:block;width:150px;height:150px;border-radius:50%;object-fit:contain;object-position:center;background:#fff;border:6px solid rgba(255,255,255,.95);box-shadow:0 14px 35px rgba(0,0,0,.20);margin:24px auto 18px;padding:12px}.hero-left h1{font-size:clamp(34px,4vw,56px);line-height:1.02;margin:10px 0 14px;letter-spacing:-.055em}.hero-bio{font-size:18px;line-height:1.7;color:var(--muted);max-width:680px}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:26px 0}.info-grid div{background:var(--surface2);border:1px solid var(--border);border-radius:20px;padding:17px;display:grid;gap:5px}.info-grid span{font-size:25px}.info-grid b{font-size:14px}.info-grid small{font-size:13px;color:var(--muted);line-height:1.35}.social-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:26px}.social-actions a{padding:13px 17px;background:var(--accent);color:var(--accentText);border-radius:15px;font-weight:950}.social-actions a:nth-child(2){background:#2c2f35;color:#fff}.social-actions .outline{background:transparent;color:var(--text);border:1px solid var(--border)}.section-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:22px}.section-heading h2{font-size:34px;line-height:1.05;margin:10px 0 0;letter-spacing:-.04em}.section-heading p{color:var(--muted);max-width:390px;margin:10px 0 0;line-height:1.45}.section-heading.center{display:block;text-align:center}.section-heading.center p{margin:10px auto 0;max-width:640px}.web-links{display:grid;gap:15px}.web-link-card{background:var(--surface);border:1px solid var(--border);border-radius:24px;overflow:hidden;box-shadow:0 12px 32px rgba(0,0,0,.06)}.web-link-main{display:grid;grid-template-columns:68px 1fr 24px;align-items:center;gap:14px;padding:18px 20px;color:var(--text)}.web-link-icon{display:grid;place-items:center;width:58px;height:58px;border-radius:18px;background:var(--surface2);font-size:32px}.web-link-icon img{width:58px;height:58px;border-radius:18px;object-fit:cover}.web-link-main strong{display:block;font-size:17px;letter-spacing:-.01em}.web-link-main small{display:block;color:var(--muted);margin-top:4px}.web-link-main b{font-size:30px;color:var(--muted)}.comments{border-top:1px solid var(--border);padding:11px 14px;text-align:left}.comments p{font-size:13px;margin:6px 0;color:var(--muted)}.comments form{display:flex;gap:8px}.comments input{flex:1;border:1px solid var(--border);border-radius:12px;padding:10px;background:var(--surface);color:var(--text)}.comments button,.primary,button{border:0;border-radius:12px;padding:10px 14px;background:var(--accent);color:var(--accentText);font-weight:900;cursor:pointer}.web-comments{background:var(--surface2)}.feedback-public{display:block!important;width:min(1240px,92vw)!important;margin:0 auto 46px!important;border-radius:34px!important;padding:36px!important;background:var(--card)!important;border:1px solid var(--border)!important;box-shadow:var(--shadow)!important}.feedback-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:15px;margin-top:24px}.feedback-card{display:flex;gap:13px;align-items:flex-start;background:var(--surface);border:1px solid var(--border);border-radius:22px;padding:18px;min-height:118px}.feedback-card p{margin:7px 0;color:var(--muted);letter-spacing:.08em;word-break:break-word}.feedback-card small{color:var(--muted)}.avatar-blur{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;flex:0 0 auto;background:linear-gradient(135deg,#c7d2fe,#f5d0fe);font-weight:950;color:#111}.censored b{filter:blur(.25px)}.feedback-card.empty{display:block;grid-column:1/-1;text-align:center}.form-page{width:min(1050px,92vw);margin:0 auto 44px;display:grid;grid-template-columns:.9fr 1.1fr;gap:24px;align-items:start}.form-intro,.form-page .form{border-radius:30px;padding:32px}.form-intro h1{font-size:42px;line-height:1.05;margin:16px 0 12px;letter-spacing:-.04em}.form-intro p{color:var(--muted);line-height:1.65}.privacy-note{margin-top:18px;padding:14px;border-radius:16px;background:var(--surface2);border:1px solid var(--border);font-weight:800}.panel{max-width:1100px;margin:0 auto 28px;padding:22px;background:var(--card);border:1px solid var(--border);border-radius:22px;box-shadow:var(--shadow)}.panel.small{max-width:560px}.form{display:grid;gap:14px}.form label{display:grid;gap:7px;font-weight:800}.form input,.form textarea,.form select,table input,table select{width:100%;padding:12px;border:1px solid var(--border);border-radius:13px;background:var(--surface);color:var(--text)}.check{display:flex!important;align-items:center;gap:8px}.check input{width:auto}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:18px}.box{border:1px solid var(--border);border-radius:16px;padding:15px;background:var(--surface2)}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}th,td{padding:10px;border-bottom:1px solid var(--border);text-align:left;vertical-align:top}.danger{background:#b42318!important;color:#fff!important}.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px}.help-reset{margin-top:16px;padding:12px;border-radius:14px;background:var(--surface2);font-size:14px}.help-reset a{font-weight:900}.preview-line{display:flex;align-items:center;gap:10px;margin:8px 0}.preview-line img{width:56px;height:56px;object-fit:contain;object-position:center;border-radius:12px;border:1px solid var(--border);background:#fff;padding:4px}.preview-emoji{width:56px;height:56px;display:grid;place-items:center;border-radius:12px;background:var(--surface);border:1px solid var(--border);font-size:28px}.admin-link-cards{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.full{width:100%;margin-top:8px}.box form+form{margin-top:8px}.mobile-linktree{display:none}.spark{position:absolute;left:20px;top:20px;background:white;color:#111;width:34px;height:34px;border-radius:50%;display:grid;place-items:center;font-size:26px}.logo{width:112px;height:112px;object-fit:contain;object-position:center;border-radius:50%;margin:75px auto 0;background:#fff;border:4px solid #fff;padding:8px;display:block;box-shadow:0 10px 26px rgba(0,0,0,.16)}.mobile-linktree h1{font-size:24px;margin:14px 0 8px}.info{font-weight:700;text-align:left;display:inline-block}.info p{margin:5px 0}.socials{display:flex;gap:26px;justify-content:center;margin:26px 0}.socials a{font-size:34px;color:var(--text);font-weight:900}.links{display:grid;gap:12px}.link-card{background:var(--surface);border-radius:12px;overflow:hidden;border:1px solid var(--border)}.link-main{display:grid;grid-template-columns:54px 1fr 20px;grid-template-rows:auto auto;align-items:center;color:var(--text);padding:10px 14px}.link-icon{grid-row:1/3;display:grid;place-items:center;width:44px;height:44px;font-size:30px}.link-icon img{width:44px;height:44px;object-fit:cover;border-radius:10px}.link-main strong{font-size:14px}.link-main small{font-size:12px;color:var(--muted)}.link-main b{grid-row:1/3;grid-column:3}.mobile-censored{margin-top:18px;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:14px;text-align:left}.mobile-censored h3{margin:0 0 8px}.mobile-censored p{font-size:13px;color:var(--muted)}@media(max-width:980px){main{padding-top:0}.site-header{padding:11px 14px;gap:8px;align-items:center}.brand span{font-size:13px}.brand img{width:34px;height:34px}.nav{gap:9px;font-size:13px;overflow-x:auto;padding-bottom:3px}.nav-btn{padding:7px 10px}.theme-toggle{width:34px;height:34px!important;font-size:15px!important}.desktop-home,.feedback-public{display:none!important}.mobile-linktree{display:block;position:relative;width:100%;max-width:430px;min-height:100vh;margin:0 auto;padding:26px 14px 36px;border-radius:0 0 26px 26px;background:var(--card);box-shadow:10px 0 0 rgba(0,0,0,.42),0 4px 20px #0002;text-align:center}.site-footer{display:block;text-align:center;padding:20px 14px}.footer-links{justify-content:center;margin-top:10px;flex-wrap:wrap}.grid2,.form-page{grid-template-columns:1fr}.panel,.form-page{margin:14px}.table-wrap table{min-width:780px}.admin-link-cards{grid-template-columns:1fr}.form-intro h1{font-size:32px}}@media(min-width:981px) and (max-width:1160px){.desktop-home{grid-template-columns:1fr}.feedback-grid{grid-template-columns:1fr 1fr}}@media(min-width:1000px){.admin-link-cards{grid-template-columns:repeat(3,minmax(0,1fr))}}
/* admin feedback full read/delete */
.feedback-admin-cards{grid-template-columns:repeat(auto-fit,minmax(310px,1fr))}
.feedback-admin-card{display:grid;gap:12px}
.feedback-admin-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.feedback-admin-head small{display:block;color:var(--muted);margin-top:3px}
.status-pill{font-size:11px;font-weight:950;letter-spacing:.04em;padding:7px 10px;border-radius:999px;background:var(--accent);color:var(--accentText);white-space:nowrap}
.feedback-message-full{padding:14px;border-radius:14px;background:var(--surface);border:1px solid var(--border);line-height:1.6;white-space:pre-wrap;word-break:break-word}
/* feedback type + multi image upload v5 */
.feedback-image-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(92px,1fr));gap:10px;margin-top:4px}
.feedback-image-gallery a{display:block;border:1px solid var(--border);border-radius:14px;overflow:hidden;background:var(--surface);box-shadow:0 8px 18px rgba(0,0,0,.06)}
.feedback-image-gallery img{width:100%;height:96px;object-fit:cover;display:block;transition:transform .18s ease}
.feedback-image-gallery a:hover img{transform:scale(1.04)}
.type-public{display:inline-block;margin-top:4px;padding:5px 9px;border-radius:999px;background:var(--surface2);border:1px solid var(--border);font-weight:800;color:var(--muted);letter-spacing:0!important}
.form input[type="file"]{padding:11px;background:var(--surface2);cursor:pointer}
.feedback-admin-card .muted{color:var(--muted)}
@media(max-width:680px){.feedback-image-gallery{grid-template-columns:repeat(3,1fr)}.feedback-image-gallery img{height:82px}}

/* production feedback page polish v6 */
.feedback-submit-page{width:min(1180px,92vw);margin:0 auto 56px;display:grid;grid-template-columns:1fr 1fr;gap:26px;align-items:start}
.feedback-hero,.feedback-form{border-radius:34px;padding:34px;overflow:hidden;position:relative}
.feedback-hero:before{content:"";position:absolute;inset:-120px -90px auto auto;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(99,102,241,.22),transparent 68%);pointer-events:none}
.feedback-hero-content{position:relative;z-index:1}
.feedback-hero h1{font-size:clamp(38px,4.6vw,64px);line-height:.98;letter-spacing:-.06em;margin:18px 0 16px}
.feedback-hero .lead{font-size:18px;line-height:1.75;color:var(--muted);max-width:560px;margin:0 0 24px}
.trust-grid{display:grid;gap:13px;margin-top:24px}
.trust-grid div{display:grid;grid-template-columns:42px 1fr;grid-template-rows:auto auto;column-gap:13px;padding:16px;border-radius:20px;background:var(--surface2);border:1px solid var(--border)}
.trust-grid span{grid-row:1/3;width:42px;height:42px;border-radius:14px;display:grid;place-items:center;background:var(--surface);font-size:22px;border:1px solid var(--border)}
.trust-grid strong{font-size:15px;letter-spacing:-.01em}
.trust-grid small{color:var(--muted);line-height:1.45;margin-top:3px}
.privacy-copy{margin:22px 0 0;padding:14px 16px;border-radius:18px;background:rgba(16,185,129,.10);border:1px solid rgba(16,185,129,.22);color:var(--muted);line-height:1.55}
.form-header{margin-bottom:20px}.form-header h2{font-size:34px;line-height:1.05;letter-spacing:-.04em;margin:14px 0 8px}.form-header p{margin:0;color:var(--muted);line-height:1.55}
.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.field-help{font-size:13px;color:var(--muted);font-weight:600;line-height:1.45;margin-top:-2px}.submit-wide{width:100%;padding:15px 18px;border-radius:16px;font-size:16px}.feedback-form label{font-size:14px;letter-spacing:-.01em}.feedback-form input,.feedback-form textarea,.feedback-form select{margin-top:3px}.feedback-form textarea{resize:vertical;min-height:190px}
html.dark .privacy-copy,html[data-theme="dark"] .privacy-copy{background:rgba(34,197,94,.10);border-color:rgba(34,197,94,.18)}
@media(max-width:980px){.feedback-submit-page{grid-template-columns:1fr;margin:18px auto 34px}.feedback-hero,.feedback-form{border-radius:26px;padding:24px}.feedback-hero h1{font-size:38px}.feedback-hero .lead{font-size:16px}.field-grid{grid-template-columns:1fr}.trust-grid div{grid-template-columns:38px 1fr}.trust-grid span{width:38px;height:38px}}

/* feedback page layout hard fix v7 */
.feedback-submit-page{
  width:min(1180px,92vw)!important;
  margin:34px auto 64px!important;
  display:grid!important;
  grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr)!important;
  gap:28px!important;
  align-items:start!important;
}
.feedback-submit-page .glass-card,
.feedback-submit-page .feedback-hero,
.feedback-submit-page .feedback-form{
  background:var(--card)!important;
  border:1px solid var(--border)!important;
  box-shadow:var(--shadow)!important;
  border-radius:34px!important;
}
.feedback-hero,
.feedback-form{
  padding:34px!important;
}
.feedback-form{
  display:grid!important;
  gap:16px!important;
}
.feedback-form label{
  display:grid!important;
  gap:7px!important;
  font-weight:850!important;
  color:var(--text)!important;
}
.feedback-form input,
.feedback-form textarea,
.feedback-form select{
  width:100%!important;
  min-width:0!important;
  padding:13px 14px!important;
  border:1px solid var(--border)!important;
  border-radius:15px!important;
  background:var(--surface)!important;
  color:var(--text)!important;
  outline:none!important;
  font:inherit!important;
}
.feedback-form input:focus,
.feedback-form textarea:focus,
.feedback-form select:focus{
  border-color:#64748b!important;
  box-shadow:0 0 0 4px rgba(100,116,139,.14)!important;
}
.feedback-form textarea{
  resize:vertical!important;
  min-height:180px!important;
}
.feedback-form input[type=file]{
  background:var(--surface2)!important;
  cursor:pointer!important;
}
.feedback-form .field-grid{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:14px!important;
}
.feedback-form .submit-wide{
  width:100%!important;
  min-height:52px!important;
  border-radius:16px!important;
  font-size:16px!important;
}
.feedback-hero h1{
  font-size:clamp(38px,4.6vw,62px)!important;
  line-height:.98!important;
  letter-spacing:-.06em!important;
  margin:18px 0 16px!important;
}
.feedback-hero .lead,
.feedback-hero .privacy-copy,
.feedback-submit-page p{
  line-height:1.65!important;
}
.trust-grid{
  display:grid!important;
  gap:13px!important;
}
.trust-grid div{
  display:grid!important;
  grid-template-columns:42px 1fr!important;
  grid-template-rows:auto auto!important;
  column-gap:13px!important;
  padding:16px!important;
  border-radius:20px!important;
  background:var(--surface2)!important;
  border:1px solid var(--border)!important;
}
.trust-grid span{
  grid-row:1/3!important;
  width:42px!important;
  height:42px!important;
  display:grid!important;
  place-items:center!important;
  border-radius:14px!important;
  background:var(--surface)!important;
  border:1px solid var(--border)!important;
}
.privacy-copy{
  padding:14px 16px!important;
  border-radius:18px!important;
  background:rgba(16,185,129,.10)!important;
  border:1px solid rgba(16,185,129,.22)!important;
}
@media(max-width:980px){
  .feedback-submit-page{grid-template-columns:1fr!important;margin:18px auto 34px!important;width:min(680px,92vw)!important;}
  .feedback-hero,.feedback-form{padding:24px!important;border-radius:26px!important;}
  .feedback-form .field-grid{grid-template-columns:1fr!important;}
}


/* admin feedback detail page v8 */
body.modal-open{overflow:hidden}.admin-feedback-page{width:min(1240px,92vw);margin:34px auto 64px;display:grid;gap:20px}.admin-feedback-hero{border-radius:34px;padding:32px;display:grid;grid-template-columns:1fr auto;gap:22px;align-items:center}.admin-feedback-hero h1{font-size:clamp(34px,4vw,56px);letter-spacing:-.055em;line-height:1;margin:14px 0 10px}.admin-feedback-hero p{color:var(--muted);line-height:1.65;max-width:680px}.feedback-summary-cards{display:grid;grid-template-columns:repeat(3,110px);gap:12px}.feedback-summary-cards div{background:var(--surface2);border:1px solid var(--border);border-radius:20px;padding:18px;text-align:center}.feedback-summary-cards b{display:block;font-size:28px;letter-spacing:-.04em}.feedback-summary-cards span{font-size:12px;color:var(--muted);font-weight:850}.admin-feedback-toolbar{display:flex;gap:12px;justify-content:flex-end;align-items:center}.outline-btn{display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:14px;padding:10px 14px;font-weight:900;cursor:pointer}.admin-feedback-list{display:grid;gap:14px}.admin-feedback-row{border-radius:26px;padding:18px;display:grid;grid-template-columns:minmax(260px,1fr) minmax(240px,1.1fr) auto;gap:18px;align-items:center}.row-main-info{display:flex;gap:14px;align-items:center}.row-main-info h3{margin:0 0 4px;font-size:18px}.row-main-info p{margin:0;color:var(--muted);font-size:13px;word-break:break-word}.row-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:9px}.row-meta span{font-size:12px;font-weight:850;color:var(--muted);padding:6px 9px;border-radius:999px;background:var(--surface2);border:1px solid var(--border)}.row-message-preview{line-height:1.55;color:var(--muted);background:var(--surface2);border:1px solid var(--border);border-radius:18px;padding:14px}.row-actions{display:flex;align-items:center;gap:10px;justify-content:flex-end;flex-wrap:wrap}.small-danger{padding:10px 12px!important}.status-dibaca{background:#2563eb!important;color:white!important}.status-selesai{background:#16a34a!important;color:white!important}.modal-backdrop,.image-zoom-backdrop{position:fixed;inset:0;z-index:1000;background:rgba(2,6,23,.72);backdrop-filter:blur(10px);display:none;padding:24px;overflow:auto}.modal-backdrop.is-open,.image-zoom-backdrop.is-open{display:flex}.feedback-detail-modal{width:min(1040px,96vw);margin:auto;border-radius:30px;padding:28px;max-height:92vh;overflow:auto}.modal-head{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;border-bottom:1px solid var(--border);padding-bottom:18px;margin-bottom:18px}.modal-head h2{margin:12px 0 6px;font-size:34px;letter-spacing:-.04em}.modal-head p{margin:0;color:var(--muted)}.modal-close{width:44px;height:44px;border-radius:50%;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:28px;line-height:1;display:grid;place-items:center;cursor:pointer}.detail-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:18px}.detail-message-box{background:var(--surface2);border:1px solid var(--border);border-radius:22px;padding:20px}.detail-message-box h3,.detail-gallery-wrap h3{margin:0 0 12px}.detail-message-box p{white-space:pre-wrap;line-height:1.75;margin:0;word-break:break-word}.detail-status-form{background:var(--surface2);border:1px solid var(--border);border-radius:22px;padding:18px}.detail-gallery-wrap{margin-top:20px}.detail-image-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px}.zoom-thumb{border:1px solid var(--border);background:var(--surface);border-radius:18px;overflow:hidden;padding:0;aspect-ratio:1/1;cursor:zoom-in;box-shadow:0 12px 28px rgba(0,0,0,.08)}.zoom-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .2s}.zoom-thumb:hover img{transform:scale(1.06)}.empty-gallery,.empty-feedback-admin{padding:28px;border-radius:22px;background:var(--surface2);border:1px dashed var(--border);color:var(--muted)}.modal-foot{border-top:1px solid var(--border);margin-top:20px;padding-top:18px;display:flex;justify-content:space-between;gap:12px;align-items:center}.image-zoom-backdrop{align-items:center;justify-content:center;cursor:zoom-out}.image-zoom-backdrop img{max-width:min(96vw,1300px);max-height:90vh;border-radius:20px;box-shadow:0 30px 90px rgba(0,0,0,.6);object-fit:contain;background:#fff}.image-zoom-close{position:fixed;right:24px;top:24px;z-index:1002}.danger{background:#dc2626!important;color:#fff!important}.admin-feedback-page .primary{display:inline-flex;align-items:center;justify-content:center}
@media(max-width:980px){.admin-feedback-hero{grid-template-columns:1fr}.feedback-summary-cards{grid-template-columns:repeat(3,1fr)}.admin-feedback-row{grid-template-columns:1fr}.row-actions{justify-content:flex-start}.detail-grid{grid-template-columns:1fr}.modal-backdrop,.image-zoom-backdrop{padding:14px}.feedback-detail-modal{padding:20px;border-radius:24px}.modal-head h2{font-size:26px}.admin-feedback-toolbar{justify-content:flex-start;flex-wrap:wrap}.detail-image-gallery{grid-template-columns:repeat(2,1fr)}}

/* responsive all devices fix v9 */
.mobile-menu-btn{display:none;border:1px solid var(--border);background:var(--surface);color:var(--text);width:44px;height:44px;border-radius:14px;font-size:24px;font-weight:950;line-height:1;cursor:pointer;box-shadow:0 8px 24px rgba(15,23,42,.08)}
.site-header{min-height:68px}.brand{min-width:0}.brand span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav{min-width:0}.nav a,.nav button{white-space:nowrap}.nav form button{font:inherit}
@media (min-width:1280px){.desktop-home,.admin-feedback-page,.feedback-submit-page{max-width:1280px}.desktop-home{grid-template-columns:1fr 1fr}.hero-left,.hero-right{min-height:520px}}
@media (max-width:1180px){.site-header{padding:12px 4vw}.site-footer{padding:24px 4vw}.desktop-home{width:min(1000px,94vw);grid-template-columns:1fr;gap:22px}.hero-left,.hero-right{padding:34px}.admin-feedback-page{width:min(1000px,94vw)}.feedback-submit-page{width:min(1000px,94vw)!important}}
@media (max-width:860px){body{background-attachment:scroll!important}.site-header{position:sticky;top:0;padding:10px 14px;align-items:center}.brand img{width:38px;height:38px}.brand span{font-size:14px;max-width:52vw}.mobile-menu-btn{display:grid;place-items:center;flex:0 0 auto}.nav{position:absolute;left:12px;right:12px;top:calc(100% + 8px);display:none;flex-direction:column;align-items:stretch;gap:8px;padding:12px;background:var(--card);border:1px solid var(--border);border-radius:22px;box-shadow:0 22px 60px rgba(15,23,42,.24);backdrop-filter:blur(18px);z-index:99}.nav.is-open{display:flex}.nav a,.nav form button,.nav-btn{width:100%;display:flex;justify-content:center;align-items:center;text-align:center;padding:12px 14px;border-radius:14px;background:var(--surface2);border:1px solid var(--border);color:var(--text)!important}.nav form{width:100%}.nav form button{background:var(--surface2)!important}.nav .theme-toggle{width:100%!important;height:44px!important;border-radius:14px!important;background:var(--accent)!important;color:var(--accentText)!important}.site-footer{flex-direction:column;align-items:flex-start}.footer-links{flex-wrap:wrap}main{padding-top:22px}.desktop-home{width:min(640px,92vw);margin:0 auto 24px;display:grid;grid-template-columns:1fr;gap:18px}.hero-left,.hero-right{padding:24px;border-radius:28px}.hero-logo{width:120px;height:120px;margin:10px auto 16px;padding:9px}.hero-left h1{font-size:clamp(30px,9vw,42px);text-align:center;word-break:break-word}.hero-bio{text-align:center;font-size:15px}.info-grid{grid-template-columns:1fr;gap:10px}.social-actions{justify-content:center}.section-heading{display:block;text-align:left}.section-heading h2{font-size:28px}.web-link-card{border-radius:22px}.web-link-main{gap:12px}.link-thumb{width:54px;height:54px}.feedback-submit-page{width:min(640px,92vw)!important;margin:18px auto 34px!important;grid-template-columns:1fr!important;gap:18px!important}.feedback-hero,.feedback-form{padding:24px!important;border-radius:28px!important}.feedback-hero h1{font-size:clamp(34px,11vw,48px)!important}.field-grid,.feedback-form .field-grid{grid-template-columns:1fr!important}.admin-feedback-page{width:min(640px,92vw);margin:18px auto 34px}.admin-feedback-hero{grid-template-columns:1fr;padding:24px;border-radius:28px}.admin-feedback-hero h1{font-size:clamp(34px,10vw,46px)}.feedback-summary-cards{grid-template-columns:repeat(3,1fr);gap:10px}.feedback-summary-cards div{padding:14px 8px}.feedback-summary-cards b{font-size:24px}.admin-feedback-toolbar{justify-content:stretch}.admin-feedback-toolbar .outline-btn,.admin-feedback-toolbar .primary{width:100%}.admin-feedback-row{grid-template-columns:1fr;padding:16px}.row-actions{justify-content:stretch}.row-actions .outline-btn,.row-actions form,.row-actions form button{width:100%}.detail-grid{grid-template-columns:1fr}.modal-backdrop,.image-zoom-backdrop{padding:12px}.feedback-detail-modal{padding:18px;border-radius:24px}.modal-head{align-items:center}.modal-head h2{font-size:24px}.detail-image-gallery{grid-template-columns:repeat(2,1fr)}}
@media (max-width:430px){.site-header{padding:9px 10px}.brand span{max-width:46vw;font-size:13px}.desktop-home,.feedback-submit-page,.admin-feedback-page{width:94vw!important}.hero-left,.hero-right,.feedback-hero,.feedback-form,.admin-feedback-hero{padding:20px!important;border-radius:24px!important}.top-kicker{font-size:11px}.hero-logo{width:106px;height:106px}.info-grid div{padding:14px}.social-actions a{width:100%;text-align:center}.web-link-main{padding:14px}.link-text strong{font-size:14px}.feedback-summary-cards{grid-template-columns:1fr 1fr 1fr}.feedback-summary-cards div{border-radius:16px}.row-main-info{align-items:flex-start}.modal-foot{flex-direction:column;align-items:stretch}.modal-foot .outline-btn,.modal-foot form,.modal-foot button{width:100%}}


/* keep background image visible in dark mode + cleaner mobile menu v10 */
html.dark .nav,html[data-theme="dark"] .nav{background:rgba(15,23,42,.92);}
html.dark .site-header,html[data-theme="dark"] .site-header,html.dark .site-footer,html[data-theme="dark"] .site-footer{background:rgba(15,23,42,.78);}
html.dark .glass-card,html[data-theme="dark"] .glass-card{background:rgba(17,24,39,.88);}
html.dark .feedback-public,html[data-theme="dark"] .feedback-public{background:rgba(17,24,39,.90)!important;}
@media(max-width:860px){
  html.dark .nav.is-open,html[data-theme="dark"] .nav.is-open{background:rgba(15,23,42,.96);}
  html.dark .nav a,html[data-theme="dark"] .nav a,html.dark .nav form button,html[data-theme="dark"] .nav form button{background:rgba(30,41,59,.92)!important;color:#eef2f7!important;}
  html.dark .nav .theme-toggle,html[data-theme="dark"] .nav .theme-toggle{background:#f8fafc!important;color:#0f172a!important;}
}

/* remove white star icon on mobile linktree */
.spark{display:none!important}
.mobile-linktree .logo{margin-top:36px!important}


/* background contrast fix v12: background image stays visible in dark/light mode */
body.has-bg-image{background-blend-mode:normal!important;}
body.has-bg-image .site-header,
body.has-bg-image .site-footer{background:rgba(255,255,255,.76)!important;backdrop-filter:blur(18px) saturate(135%)!important;}
body.has-bg-image .glass-card,
body.has-bg-image .feedback-public,
body.has-bg-image .panel,
body.has-bg-image .feedback-hero,
body.has-bg-image .feedback-form,
body.has-bg-image .admin-feedback-hero,
body.has-bg-image .admin-feedback-row,
body.has-bg-image .feedback-detail-modal{background:rgba(255,255,255,.84)!important;backdrop-filter:blur(18px) saturate(135%)!important;}
body.has-bg-image .web-link-card,
body.has-bg-image .feedback-card,
body.has-bg-image .link-card,
body.has-bg-image .mobile-censored,
body.has-bg-image .info-grid div,
body.has-bg-image .box,
body.has-bg-image .trust-grid div{background:rgba(248,250,252,.82)!important;backdrop-filter:blur(10px)!important;}
html.dark body.has-bg-image,
html[data-theme="dark"] body.has-bg-image{background-color:#0f172a!important;}
html.dark body.has-bg-image .site-header,
html[data-theme="dark"] body.has-bg-image .site-header,
html.dark body.has-bg-image .site-footer,
html[data-theme="dark"] body.has-bg-image .site-footer{background:rgba(15,23,42,.72)!important;border-color:rgba(148,163,184,.22)!important;}
html.dark body.has-bg-image .glass-card,
html[data-theme="dark"] body.has-bg-image .glass-card,
html.dark body.has-bg-image .feedback-public,
html[data-theme="dark"] body.has-bg-image .feedback-public,
html.dark body.has-bg-image .panel,
html[data-theme="dark"] body.has-bg-image .panel,
html.dark body.has-bg-image .feedback-hero,
html[data-theme="dark"] body.has-bg-image .feedback-hero,
html.dark body.has-bg-image .feedback-form,
html[data-theme="dark"] body.has-bg-image .feedback-form,
html.dark body.has-bg-image .admin-feedback-hero,
html[data-theme="dark"] body.has-bg-image .admin-feedback-hero,
html.dark body.has-bg-image .admin-feedback-row,
html[data-theme="dark"] body.has-bg-image .admin-feedback-row,
html.dark body.has-bg-image .feedback-detail-modal,
html[data-theme="dark"] body.has-bg-image .feedback-detail-modal{background:rgba(15,23,42,.68)!important;border-color:rgba(148,163,184,.24)!important;backdrop-filter:blur(16px) saturate(130%)!important;}
html.dark body.has-bg-image .web-link-card,
html[data-theme="dark"] body.has-bg-image .web-link-card,
html.dark body.has-bg-image .feedback-card,
html[data-theme="dark"] body.has-bg-image .feedback-card,
html.dark body.has-bg-image .link-card,
html[data-theme="dark"] body.has-bg-image .link-card,
html.dark body.has-bg-image .mobile-censored,
html[data-theme="dark"] body.has-bg-image .mobile-censored,
html.dark body.has-bg-image .info-grid div,
html[data-theme="dark"] body.has-bg-image .info-grid div,
html.dark body.has-bg-image .box,
html[data-theme="dark"] body.has-bg-image .box,
html.dark body.has-bg-image .trust-grid div,
html[data-theme="dark"] body.has-bg-image .trust-grid div{background:rgba(30,41,59,.64)!important;border-color:rgba(148,163,184,.22)!important;backdrop-filter:blur(12px)!important;}
html.dark body.has-bg-image .mobile-linktree,
html[data-theme="dark"] body.has-bg-image .mobile-linktree{background:rgba(15,23,42,.66)!important;backdrop-filter:blur(14px) saturate(130%)!important;box-shadow:none!important;}
body.no-bg-image .site-header,body.no-bg-image .site-footer{background:var(--glass)!important;}
body.no-bg-image .glass-card,body.no-bg-image .feedback-public,body.no-bg-image .panel{background:var(--card)!important;}
html.dark body.no-bg-image .site-header,html[data-theme="dark"] body.no-bg-image .site-header,html.dark body.no-bg-image .site-footer,html[data-theme="dark"] body.no-bg-image .site-footer{background:#0f172a!important;}
html.dark body.no-bg-image .glass-card,html[data-theme="dark"] body.no-bg-image .glass-card,html.dark body.no-bg-image .feedback-public,html[data-theme="dark"] body.no-bg-image .feedback-public,html.dark body.no-bg-image .panel,html[data-theme="dark"] body.no-bg-image .panel{background:#111827!important;}
@media(max-width:980px){
  body.has-bg-image .mobile-linktree{background:rgba(255,255,255,.78)!important;backdrop-filter:blur(14px) saturate(130%)!important;}
  html.dark body.has-bg-image .mobile-linktree,html[data-theme="dark"] body.has-bg-image .mobile-linktree{background:rgba(15,23,42,.66)!important;}
}
@media(max-width:860px){
  html.dark body.has-bg-image .nav.is-open,html[data-theme="dark"] body.has-bg-image .nav.is-open{background:rgba(15,23,42,.78)!important;}
  body.has-bg-image .nav.is-open{background:rgba(255,255,255,.82)!important;}
}

/* login-required feedback form v13 */
.identity-card{
  display:flex;
  align-items:center;
  gap:14px;
  padding:16px;
  border:1px solid var(--border);
  border-radius:18px;
  background:rgba(248,250,252,.86);
  margin-bottom:16px;
}
.identity-avatar{
  width:52px;
  height:52px;
  border-radius:16px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  font-size:20px;
  color:#111827;
  background:linear-gradient(135deg,#ffffff,#e0e7ff);
  border:1px solid var(--border);
  flex:0 0 auto;
}
.identity-card span,.identity-card small{display:block;color:var(--muted);font-size:13px;line-height:1.45}
.identity-card strong{display:block;font-size:16px;line-height:1.3;color:var(--text)}
.auth-required-page{max-width:980px;margin:0 auto;padding:70px 18px 90px;display:block}
.auth-required-card{max-width:820px;margin:0 auto}
.auth-required-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-top:22px}
.ghost-link{font-weight:900;text-decoration:none;color:var(--muted);padding:12px 14px}
html.dark .identity-card,html[data-theme="dark"] .identity-card{background:rgba(30,41,59,.72);border-color:rgba(148,163,184,.28)}
html.dark .identity-avatar,html[data-theme="dark"] .identity-avatar{background:linear-gradient(135deg,#1e293b,#334155);color:#f8fafc;border-color:rgba(148,163,184,.25)}
html.dark body.has-bg-image .identity-card,html[data-theme="dark"] body.has-bg-image .identity-card{background:rgba(30,41,59,.64)!important;border-color:rgba(148,163,184,.24)!important}
@media(max-width:720px){
  .auth-required-page{padding:34px 14px 70px}
  .auth-required-actions{flex-direction:column;align-items:stretch}
  .auth-required-actions a{width:100%;text-align:center;justify-content:center}
  .identity-card{align-items:flex-start;padding:14px;border-radius:16px}
}

/* username size fix v13 */
.hero-left h1{
  font-size:clamp(28px,2.7vw,40px)!important;
  line-height:1.12!important;
  letter-spacing:-.035em!important;
  word-break:break-word!important;
  overflow-wrap:anywhere!important;
  max-width:100%!important;
}
@media (min-width:1200px){
  .hero-left h1{font-size:38px!important;}
}
@media (max-width:860px){
  .hero-left h1,.mobile-linktree h1{
    font-size:clamp(22px,6.2vw,28px)!important;
    line-height:1.18!important;
    letter-spacing:-.025em!important;
    word-break:break-word!important;
    overflow-wrap:anywhere!important;
  }
}
@media (max-width:430px){
  .hero-left h1,.mobile-linktree h1{
    font-size:24px!important;
  }
}

/* username center position fix v14 */
.hero-left{
  text-align:center!important;
}
.hero-left .top-kicker{
  margin-left:auto!important;
  margin-right:auto!important;
}
.hero-left h1{
  text-align:center!important;
  margin-left:auto!important;
  margin-right:auto!important;
  max-width:720px!important;
}
.hero-left .hero-bio{
  text-align:center!important;
  margin-left:auto!important;
  margin-right:auto!important;
}
.info-grid{
  text-align:left!important;
}
.social-actions{
  justify-content:center!important;
}
@media (max-width:860px){
  .hero-left h1,.mobile-linktree h1{
    text-align:center!important;
    margin-left:auto!important;
    margin-right:auto!important;
  }
  .mobile-linktree .info{text-align:left!important;}
}


/* profile info alignment fix v15 */
.hero-left{
  text-align:left!important;
}
.hero-left .top-kicker{
  margin-left:0!important;
  margin-right:0!important;
}
.hero-left .hero-logo{
  margin-left:auto!important;
  margin-right:auto!important;
}
.hero-left h1{
  text-align:center!important;
  margin-left:auto!important;
  margin-right:auto!important;
}
.hero-left .hero-bio{
  text-align:left!important;
  margin:0 0 14px!important;
  max-width:none!important;
}
.hero-quick-info{
  width:100%;
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px 18px;
  margin:18px 0 22px;
  color:var(--muted);
  font-size:16px;
  line-height:1.55;
  text-align:left;
}
.hero-quick-info span{
  display:flex;
  align-items:flex-start;
  gap:8px;
  min-width:0;
}
.hero-quick-info b{
  font-weight:700;
  color:var(--muted);
  overflow-wrap:anywhere;
}
.info-grid{
  margin-top:16px!important;
}
@media (max-width:860px){
  .hero-left .top-kicker{margin-left:0!important;margin-right:0!important;}
  .hero-quick-info{grid-template-columns:1fr;font-size:14px;gap:8px;margin:16px 0 18px;}
  .hero-left .hero-bio{text-align:left!important;}
}


/* profile layout alignment fix v16 - force left badge + clean 2-column info */
.hero-left{
  display:flex!important;
  flex-direction:column!important;
  align-items:stretch!important;
  text-align:left!important;
}
.hero-left .top-kicker{
  align-self:flex-start!important;
  margin:0 0 22px 0!important;
}
.hero-left .hero-logo{
  align-self:center!important;
  margin:0 auto 18px auto!important;
}
.hero-left h1{
  width:100%!important;
  max-width:100%!important;
  text-align:center!important;
  margin:0 auto 14px auto!important;
  overflow-wrap:anywhere!important;
}
.hero-left .hero-bio{
  width:100%!important;
  text-align:left!important;
  margin:0 0 18px 0!important;
}
.hero-quick-info{
  width:100%!important;
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:12px 16px!important;
  margin:0 0 22px 0!important;
  text-align:left!important;
  justify-items:stretch!important;
  align-items:start!important;
}
.hero-quick-info span{
  display:flex!important;
  justify-content:flex-start!important;
  align-items:flex-start!important;
  gap:9px!important;
  min-width:0!important;
  line-height:1.5!important;
  text-align:left!important;
}
.hero-quick-info b{
  display:block!important;
  color:var(--muted)!important;
  font-weight:700!important;
  text-align:left!important;
  overflow-wrap:anywhere!important;
}
.info-grid{
  width:100%!important;
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:14px!important;
  text-align:left!important;
  margin-top:0!important;
}
.info-grid div{text-align:left!important;align-items:flex-start!important;}
.social-actions{justify-content:flex-start!important;}
@media (max-width:860px){
  .hero-left .top-kicker{align-self:flex-start!important;margin-bottom:18px!important;}
  .hero-quick-info,.info-grid{grid-template-columns:1fr!important;}
  .social-actions{justify-content:stretch!important;}
}


/* no double profile info fix v17 */
.hero-quick-info{display:none!important;}
.hero-left{align-items:stretch!important;text-align:left!important;}
.hero-left .top-kicker{align-self:flex-start!important;margin:0 0 22px 0!important;}
.hero-left .hero-logo{align-self:center!important;margin:0 auto 18px!important;}
.hero-left h1{text-align:center!important;margin:0 auto 20px!important;}
.info-grid{display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:14px!important;margin:0 0 26px!important;text-align:left!important;}
.info-grid div{display:flex!important;flex-direction:column!important;align-items:flex-start!important;text-align:left!important;min-height:112px;}
.social-actions{justify-content:flex-start!important;margin-top:0!important;}
@media(max-width:860px){
  .hero-left .top-kicker{align-self:flex-start!important;}
  .info-grid{grid-template-columns:1fr!important;}
  .social-actions{justify-content:stretch!important;}
}


/* no double profile info fix v18 - final clean profile block */
.hero-profile-clean .hero-quick-info,
.hero-profile-clean .profile-meta,
.hero-profile-clean .hero-meta,
.hero-profile-clean .hero-info,
.hero-profile-clean .profile-info-line,
.hero-profile-clean .profile-summary,
.hero-profile-clean > .info:not(.only-profile-info){
  display:none!important;
}
.hero-profile-clean{
  display:flex!important;
  flex-direction:column!important;
  align-items:stretch!important;
  text-align:left!important;
}
.hero-profile-clean > .top-kicker{
  align-self:flex-start!important;
  margin:0 0 22px!important;
}
.hero-profile-clean > .hero-logo{
  align-self:center!important;
  margin:0 auto 18px!important;
}
.hero-profile-clean > h1{
  width:100%!important;
  text-align:center!important;
  margin:0 auto 22px!important;
  font-size:clamp(28px,2.7vw,40px)!important;
  line-height:1.12!important;
  overflow-wrap:anywhere!important;
}
.hero-profile-clean > .hero-bio{
  text-align:left!important;
  margin:0 0 18px!important;
}
.hero-profile-clean .only-profile-info{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:14px!important;
  margin:0 0 26px!important;
  text-align:left!important;
}
.hero-profile-clean .only-profile-info > div{
  display:flex!important;
  flex-direction:column!important;
  align-items:flex-start!important;
  justify-content:flex-start!important;
  text-align:left!important;
  min-height:112px!important;
}
.hero-profile-clean .only-profile-info small,
.hero-profile-clean .only-profile-info b{
  text-align:left!important;
}
.hero-profile-clean .social-actions{
  justify-content:flex-start!important;
}
@media(max-width:860px){
  .hero-profile-clean .only-profile-info{grid-template-columns:1fr!important;}
  .hero-profile-clean .social-actions{justify-content:stretch!important;}
}


/* auth buttons side-by-side fix v19 */
.auth-required-actions{
  display:flex!important;
  flex-direction:column!important;
  gap:14px!important;
  align-items:stretch!important;
  width:100%!important;
  margin-top:22px!important;
}
.auth-action-row{
  display:flex!important;
  flex-direction:row!important;
  gap:12px!important;
  align-items:center!important;
  justify-content:flex-start!important;
  flex-wrap:nowrap!important;
  width:100%!important;
}
.auth-btn{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  min-height:48px!important;
  padding:12px 18px!important;
  border-radius:14px!important;
  font-weight:950!important;
  text-decoration:none!important;
  white-space:nowrap!important;
  flex:1 1 0!important;
  text-align:center!important;
  line-height:1.15!important;
}
.auth-btn-primary{
  background:#fff!important;
  color:#0f172a!important;
  border:1px solid #fff!important;
  box-shadow:0 12px 28px rgba(15,23,42,.14)!important;
}
.auth-btn-outline{
  background:rgba(15,23,42,.28)!important;
  color:#fff!important;
  border:1px solid rgba(255,255,255,.28)!important;
}
html:not(.dark) .auth-btn-outline, html:not([data-theme="dark"]) .auth-btn-outline{
  color:var(--text)!important;
  background:var(--surface)!important;
  border:1px solid var(--border)!important;
}
.auth-back-link{
  display:inline-flex!important;
  width:max-content!important;
  max-width:100%!important;
  margin-top:2px!important;
}
@media(max-width:430px){
  .auth-action-row{gap:9px!important;}
  .auth-btn{min-height:44px!important;padding:10px 12px!important;font-size:13px!important;border-radius:12px!important;}
}

/* login required action box fix v20 */
.login-required-box{
  width:100%!important;
  margin-top:22px!important;
  padding:16px!important;
  border-radius:22px!important;
  border:1px solid rgba(255,255,255,.16)!important;
  background:rgba(15,23,42,.42)!important;
  box-shadow:0 18px 46px rgba(2,6,23,.16)!important;
  backdrop-filter:blur(12px)!important;
}
.login-required-box-head{
  display:flex!important;
  align-items:center!important;
  gap:12px!important;
  margin-bottom:14px!important;
}
.login-required-icon{
  width:42px!important;
  height:42px!important;
  border-radius:14px!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  background:rgba(255,255,255,.1)!important;
  border:1px solid rgba(255,255,255,.14)!important;
  flex:0 0 42px!important;
}
.login-required-box-head strong{
  display:block!important;
  font-size:16px!important;
  line-height:1.2!important;
  color:#fff!important;
  font-weight:950!important;
}
.login-required-box-head small{
  display:block!important;
  margin-top:4px!important;
  color:rgba(226,232,240,.78)!important;
  font-weight:700!important;
  line-height:1.35!important;
}
.login-required-box .auth-required-actions{margin-top:0!important;}
html:not(.dark) .login-required-box,
html:not([data-theme="dark"]) .login-required-box{
  background:rgba(255,255,255,.82)!important;
  border:1px solid rgba(15,23,42,.1)!important;
}
html:not(.dark) .login-required-box-head strong,
html:not([data-theme="dark"]) .login-required-box-head strong{color:var(--text)!important;}
html:not(.dark) .login-required-box-head small,
html:not([data-theme="dark"]) .login-required-box-head small{color:var(--muted)!important;}
html:not(.dark) .login-required-icon,
html:not([data-theme="dark"]) .login-required-icon{
  background:rgba(15,23,42,.06)!important;
  border-color:rgba(15,23,42,.1)!important;
}
@media(max-width:560px){
  .login-required-box{padding:14px!important;border-radius:20px!important;}
  .login-required-box-head{align-items:flex-start!important;}
  .login-required-box-head strong{font-size:15px!important;}
  .login-required-box-head small{font-size:12px!important;}
}

/* login required right side box fix v21 */
.auth-required-sidebox-page{
  width:min(1180px,92vw)!important;
  max-width:1180px!important;
  margin:0 auto 70px!important;
  padding:64px 0 88px!important;
  display:grid!important;
  grid-template-columns:minmax(0,1fr) minmax(360px,0.92fr)!important;
  gap:28px!important;
  align-items:stretch!important;
}
.auth-required-sidebox-page .auth-required-card,
.auth-required-sidebox-page .login-required-side-card{
  max-width:none!important;
  width:100%!important;
  margin:0!important;
}
.login-required-side-card{
  display:flex!important;
  flex-direction:column!important;
  justify-content:center!important;
  min-height:100%!important;
  padding:38px!important;
}
.login-required-side-card .side-card-icon{
  width:64px!important;
  height:64px!important;
  border-radius:22px!important;
  display:grid!important;
  place-items:center!important;
  margin:22px 0 16px!important;
  font-size:28px!important;
  background:rgba(255,255,255,.12)!important;
  border:1px solid rgba(255,255,255,.18)!important;
}
.login-required-side-card h2{
  margin:0 0 12px!important;
  font-size:clamp(30px,3vw,48px)!important;
  line-height:1.02!important;
  letter-spacing:-.045em!important;
  color:var(--text)!important;
}
.login-required-side-card p{
  color:var(--muted)!important;
  font-size:16px!important;
  line-height:1.7!important;
  margin:0 0 18px!important;
}
.side-login-benefits{
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:12px!important;
  margin:8px 0 18px!important;
}
.side-login-benefits div{
  display:grid!important;
  grid-template-columns:42px 1fr!important;
  gap:12px!important;
  align-items:center!important;
  padding:14px!important;
  border-radius:18px!important;
  background:var(--surface2)!important;
  border:1px solid var(--border)!important;
}
.side-login-benefits span{
  width:42px!important;
  height:42px!important;
  display:grid!important;
  place-items:center!important;
  border-radius:14px!important;
  background:rgba(255,255,255,.1)!important;
  grid-row:span 2!important;
}
.side-login-benefits b,
.side-login-benefits small{display:block!important;}
.side-login-benefits b{font-weight:950!important;color:var(--text)!important;}
.side-login-benefits small{color:var(--muted)!important;line-height:1.35!important;}
.side-login-box{margin-top:auto!important;}
html:not(.dark) .login-required-side-card .side-card-icon,
html:not([data-theme="dark"]) .login-required-side-card .side-card-icon{
  background:rgba(15,23,42,.06)!important;
  border-color:rgba(15,23,42,.1)!important;
}
@media(max-width:980px){
  .auth-required-sidebox-page{
    grid-template-columns:1fr!important;
    width:min(680px,92vw)!important;
    padding:28px 0 70px!important;
    gap:18px!important;
  }
  .login-required-side-card{padding:24px!important;border-radius:28px!important;}
  .login-required-side-card h2{font-size:clamp(28px,8vw,38px)!important;}
}
@media(max-width:480px){
  .auth-required-sidebox-page{width:94vw!important;padding-top:18px!important;}
  .login-required-side-card{padding:20px!important;border-radius:24px!important;}
  .login-required-side-card .side-card-icon{width:54px!important;height:54px!important;border-radius:18px!important;font-size:24px!important;}
  .auth-action-row{grid-template-columns:1fr 1fr!important;display:grid!important;gap:10px!important;}
  .auth-btn{min-width:0!important;white-space:normal!important;}
}

/* clear login/register choice cards fix v22 */
.login-choice-panel{
  padding:20px!important;
  border-radius:26px!important;
  background:rgba(15,23,42,.58)!important;
  border:1px solid rgba(255,255,255,.16)!important;
}
.login-choice-grid{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:14px!important;
  width:100%!important;
  margin-top:18px!important;
}
.login-choice-card{
  position:relative!important;
  display:flex!important;
  flex-direction:column!important;
  min-height:156px!important;
  padding:16px!important;
  border-radius:20px!important;
  text-decoration:none!important;
  overflow:hidden!important;
  transition:transform .18s ease, border-color .18s ease, box-shadow .18s ease!important;
}
.login-choice-card:hover{
  transform:translateY(-2px)!important;
  box-shadow:0 18px 42px rgba(2,6,23,.24)!important;
}
.login-choice-login{
  background:#ffffff!important;
  color:#0f172a!important;
  border:1px solid rgba(255,255,255,.88)!important;
}
.login-choice-register{
  background:rgba(255,255,255,.06)!important;
  color:#ffffff!important;
  border:1px solid rgba(255,255,255,.18)!important;
}
.choice-icon{
  width:38px!important;
  height:38px!important;
  border-radius:14px!important;
  display:grid!important;
  place-items:center!important;
  margin-bottom:12px!important;
  background:rgba(15,23,42,.08)!important;
  border:1px solid rgba(15,23,42,.08)!important;
}
.login-choice-register .choice-icon{
  background:rgba(255,255,255,.10)!important;
  border-color:rgba(255,255,255,.12)!important;
}
.choice-title{
  display:block!important;
  font-size:15px!important;
  line-height:1.25!important;
  font-weight:950!important;
  margin-bottom:5px!important;
}
.choice-desc{
  display:block!important;
  font-size:12.5px!important;
  line-height:1.45!important;
  font-weight:700!important;
  opacity:.72!important;
  margin-bottom:14px!important;
}
.choice-button{
  margin-top:auto!important;
  min-height:42px!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  width:100%!important;
  padding:10px 12px!important;
  border-radius:14px!important;
  font-size:14px!important;
  font-weight:950!important;
  line-height:1.1!important;
  white-space:nowrap!important;
}
.login-choice-login .choice-button{
  color:#ffffff!important;
  background:#0f172a!important;
}
.login-choice-register .choice-button{
  color:#0f172a!important;
  background:#ffffff!important;
}
.login-choice-panel .auth-back-link{
  margin-top:14px!important;
  display:inline-flex!important;
}
html:not(.dark) .login-choice-panel,
html:not([data-theme="dark"]) .login-choice-panel{
  background:rgba(255,255,255,.86)!important;
  border:1px solid rgba(15,23,42,.10)!important;
}
html:not(.dark) .login-choice-register,
html:not([data-theme="dark"]) .login-choice-register{
  color:#0f172a!important;
  background:rgba(15,23,42,.04)!important;
  border:1px solid rgba(15,23,42,.12)!important;
}
html:not(.dark) .login-choice-register .choice-icon,
html:not([data-theme="dark"]) .login-choice-register .choice-icon{
  background:rgba(15,23,42,.06)!important;
  border-color:rgba(15,23,42,.08)!important;
}
@media(max-width:520px){
  .login-choice-grid{grid-template-columns:1fr!important;gap:12px!important;}
  .login-choice-card{min-height:auto!important;padding:15px!important;}
  .choice-button{min-height:44px!important;}
}


/* login/register real button box fix v23 */
.login-choice-box-v23{
  display:flex!important;
  flex-direction:column!important;
  gap:18px!important;
}
.login-choice-box-v23 .login-choice-intro{
  display:flex!important;
  gap:14px!important;
  align-items:flex-start!important;
}
.login-choice-lock{
  width:52px!important;
  height:52px!important;
  border-radius:18px!important;
  display:grid!important;
  place-items:center!important;
  background:rgba(255,255,255,.10)!important;
  border:1px solid rgba(255,255,255,.14)!important;
  font-size:24px!important;
  flex:0 0 auto!important;
}
.login-choice-box-v23 h2{
  margin:0 0 8px!important;
  font-size:clamp(26px,2.4vw,38px)!important;
  line-height:1.08!important;
}
.login-choice-box-v23 p{
  margin:0!important;
  line-height:1.65!important;
}
.login-choice-mainbox{
  padding:20px!important;
  border-radius:24px!important;
  background:rgba(255,255,255,.08)!important;
  border:1px solid rgba(255,255,255,.16)!important;
  box-shadow:0 18px 50px rgba(2,6,23,.18)!important;
}
.login-choice-titleline{
  display:flex!important;
  flex-direction:column!important;
  gap:4px!important;
  margin-bottom:16px!important;
}
.login-choice-titleline strong{
  color:#fff!important;
  font-size:18px!important;
  font-weight:950!important;
}
.login-choice-titleline small{
  color:rgba(255,255,255,.72)!important;
  font-size:13px!important;
  line-height:1.45!important;
}
.login-choice-buttons-v23{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:14px!important;
  width:100%!important;
}
.login-choice-bigbtn{
  display:flex!important;
  align-items:center!important;
  gap:13px!important;
  min-height:86px!important;
  padding:16px!important;
  border-radius:20px!important;
  text-decoration:none!important;
  border:1px solid rgba(255,255,255,.18)!important;
  transition:transform .18s ease, box-shadow .18s ease!important;
}
.login-choice-bigbtn:hover{
  transform:translateY(-2px)!important;
  box-shadow:0 18px 36px rgba(0,0,0,.22)!important;
}
.btn-login-v23{
  background:#fff!important;
  color:#0f172a!important;
  border-color:#fff!important;
}
.btn-register-v23{
  background:rgba(255,255,255,.06)!important;
  color:#fff!important;
  border-color:rgba(255,255,255,.20)!important;
}
.bigbtn-icon{
  width:44px!important;
  height:44px!important;
  border-radius:16px!important;
  display:grid!important;
  place-items:center!important;
  flex:0 0 auto!important;
  background:rgba(15,23,42,.08)!important;
  border:1px solid rgba(15,23,42,.08)!important;
  font-size:22px!important;
}
.btn-register-v23 .bigbtn-icon{
  background:rgba(255,255,255,.12)!important;
  border-color:rgba(255,255,255,.12)!important;
}
.bigbtn-text{
  display:flex!important;
  flex-direction:column!important;
  gap:3px!important;
  min-width:0!important;
}
.bigbtn-text b{
  display:block!important;
  font-size:16px!important;
  line-height:1.15!important;
  font-weight:950!important;
  white-space:normal!important;
}
.bigbtn-text small{
  display:block!important;
  font-size:12.5px!important;
  line-height:1.25!important;
  opacity:.72!important;
  font-weight:800!important;
}
.login-choice-note-v23{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:12px!important;
}
.login-choice-note-v23>div{
  padding:14px!important;
  border-radius:18px!important;
  background:rgba(255,255,255,.06)!important;
  border:1px solid rgba(255,255,255,.12)!important;
  display:grid!important;
  grid-template-columns:auto 1fr!important;
  column-gap:10px!important;
  row-gap:2px!important;
}
.login-choice-note-v23 span{grid-row:1 / span 2!important;}
.login-choice-note-v23 b{color:#fff!important;font-size:14px!important;}
.login-choice-note-v23 small{color:rgba(255,255,255,.72)!important;font-size:12px!important;line-height:1.35!important;}
html:not(.dark) .login-choice-mainbox,
html:not([data-theme="dark"]) .login-choice-mainbox{
  background:rgba(255,255,255,.90)!important;
  border-color:rgba(15,23,42,.10)!important;
}
html:not(.dark) .login-choice-titleline strong,
html:not([data-theme="dark"]) .login-choice-titleline strong{color:#0f172a!important;}
html:not(.dark) .login-choice-titleline small,
html:not([data-theme="dark"]) .login-choice-titleline small{color:#64748b!important;}
html:not(.dark) .btn-register-v23,
html:not([data-theme="dark"]) .btn-register-v23{
  background:#0f172a!important;
  color:#fff!important;
  border-color:#0f172a!important;
}
html:not(.dark) .login-choice-note-v23>div,
html:not([data-theme="dark"]) .login-choice-note-v23>div{
  background:rgba(15,23,42,.04)!important;
  border-color:rgba(15,23,42,.10)!important;
}
html:not(.dark) .login-choice-note-v23 b,
html:not([data-theme="dark"]) .login-choice-note-v23 b{color:#0f172a!important;}
html:not(.dark) .login-choice-note-v23 small,
html:not([data-theme="dark"]) .login-choice-note-v23 small{color:#64748b!important;}
@media(max-width:720px){
  .login-choice-box-v23 .login-choice-intro{flex-direction:column!important;}
  .login-choice-buttons-v23{grid-template-columns:1fr!important;}
  .login-choice-note-v23{grid-template-columns:1fr!important;}
  .login-choice-bigbtn{min-height:76px!important;}
}

/* header spacing fix v24 */
@media (min-width:861px){
  .site-header{
    padding-left:clamp(28px,7vw,128px)!important;
    padding-right:clamp(28px,7vw,128px)!important;
  }
  .nav{
    gap:22px!important;
    align-items:center!important;
  }
  .nav a,
  .nav form button{
    padding:8px 2px!important;
    line-height:1.2!important;
  }
  .nav .nav-btn{
    padding:12px 24px!important;
    margin-left:2px!important;
  }
  .theme-toggle{
    margin-left:6px!important;
    flex:0 0 44px!important;
  }
}
@media (min-width:861px) and (max-width:1120px){
  .nav{gap:16px!important;font-size:14px!important;}
  .nav .nav-btn{padding:10px 20px!important;}
}

/* Private feedback two-way chat session v26 */
.my-feedback-panel{min-width:0}.my-feedback-card{border:1px solid rgba(100,116,139,.18);border-radius:24px;padding:18px;margin-top:16px;background:rgba(255,255,255,.82);box-shadow:0 14px 40px rgba(15,23,42,.08)}.my-feedback-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:14px}.my-feedback-head h3{margin:0;font-size:18px}.my-feedback-head p{margin:6px 0 0;color:#64748b}.feedback-chat-box{margin-top:22px;border:1px solid rgba(100,116,139,.22);border-radius:24px;padding:18px;background:linear-gradient(180deg,rgba(248,250,252,.9),rgba(255,255,255,.74))}.chat-headline{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;margin-bottom:16px}.chat-headline h3,.chat-headline h2{margin:0 0 5px}.chat-headline p{margin:0;color:#64748b}.session-pill{display:inline-flex;align-items:center;white-space:nowrap;border-radius:999px;padding:8px 12px;font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.03em}.session-pill.open{background:#dcfce7;color:#166534}.session-pill.closed{background:#fee2e2;color:#991b1b}.chat-thread{display:flex;flex-direction:column;gap:12px;max-height:340px;overflow:auto;padding:8px;border-radius:18px;background:rgba(241,245,249,.72)}.chat-thread.compact{max-height:280px}.chat-bubble{max-width:82%;padding:12px 14px;border-radius:18px;border:1px solid rgba(100,116,139,.18);box-shadow:0 8px 20px rgba(15,23,42,.05)}.chat-bubble.from-sender{align-self:flex-start;background:#fff}.chat-bubble.from-admin{align-self:flex-end;background:#111827;color:#fff}.chat-bubble.from-admin .chat-meta span{color:#cbd5e1}.chat-bubble p{margin:8px 0 0;white-space:pre-wrap;line-height:1.5}.chat-meta{display:flex;gap:10px;justify-content:space-between;align-items:center;font-size:12px}.chat-meta span{color:#64748b}.chat-reply-form{display:grid;grid-template-columns:1fr auto;gap:12px;margin-top:14px}.chat-reply-form textarea{width:100%;min-height:82px;border-radius:16px;border:1px solid rgba(100,116,139,.28);padding:13px 14px;resize:vertical;background:#fff;color:#0f172a}.closed-note{padding:14px;border-radius:16px;background:#fff7ed;color:#9a3412;border:1px solid #fed7aa;margin-top:12px}.chat-modal{max-width:1050px}.chat-modal .detail-grid{grid-template-columns:1.1fr .9fr}
[data-theme="dark"] .my-feedback-card,[data-theme="dark"] .feedback-chat-box{background:rgba(15,23,42,.82);border-color:rgba(148,163,184,.25)}[data-theme="dark"] .chat-thread{background:rgba(2,6,23,.5)}[data-theme="dark"] .chat-bubble.from-sender{background:#0f172a;color:#e5e7eb}[data-theme="dark"] .chat-reply-form textarea{background:#0f172a;color:#e5e7eb;border-color:rgba(148,163,184,.3)}[data-theme="dark"] .closed-note{background:rgba(124,45,18,.3);border-color:rgba(251,146,60,.35);color:#fed7aa}
@media(max-width:900px){.dashboard-page{grid-template-columns:1fr}.chat-reply-form{grid-template-columns:1fr}.chat-bubble{max-width:95%}.chat-headline,.my-feedback-head{flex-direction:column}.chat-modal .detail-grid{grid-template-columns:1fr}}

/* v27 security code for protected sender types */
.security-code-field{display:none;position:relative}
.security-code-field input{letter-spacing:.18em;font-weight:900}
.security-code-field::before{content:'🔒';position:absolute;right:16px;top:43px;opacity:.65;pointer-events:none}
html.dark .security-code-field input,html[data-theme="dark"] .security-code-field input{background:rgba(15,23,42,.92)!important;color:#eef2f7!important;border-color:#475569!important}

/* v28: readonly login email + admin managed secret codes */
.readonly-field,
.feedback-form input.readonly-field{
  opacity:.82;
  cursor:not-allowed;
  background:rgba(148,163,184,.12)!important;
  border-style:dashed!important;
}
.security-code-admin-box{margin-bottom:22px}
.security-code-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px}
.security-code-grid input{font-weight:900;letter-spacing:.12em}
@media(max-width:860px){.security-code-grid{grid-template-columns:1fr}}


/* V29: pisahkan riwayat kritik & saran dari dashboard */
.dashboard-page{display:grid;gap:24px;align-items:start;justify-content:center;padding:48px 18px 70px;}
.dashboard-page .panel.small{max-width:620px;width:min(620px,100%);margin:0 auto;}
.dashboard-note-panel{width:min(620px,100%);margin:0 auto;padding:28px;}
.action-row{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-top:18px;}
.primary.small-link{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;border-radius:16px;padding:12px 18px;font-weight:800;}
.split-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;}
.history-btn{white-space:nowrap;margin-top:8px;}
.feedback-history-page{min-height:calc(100vh - 160px);padding:52px 18px 80px;display:flex;justify-content:center;}
.history-panel{width:min(1040px,100%);padding:32px;}
.compact-actions{margin-top:0;justify-content:flex-end;}
.history-images{display:flex;gap:10px;flex-wrap:wrap;margin:14px 0 8px;}
.history-images a{display:block;width:86px;height:86px;border-radius:18px;overflow:hidden;border:1px solid var(--line);background:rgba(255,255,255,.08);}
.history-images img{width:100%;height:100%;object-fit:cover;display:block;transition:.2s ease;}
.history-images a:hover img{transform:scale(1.08);}
@media(max-width:760px){
  .split-header{display:block;}
  .history-btn{margin-top:14px;width:100%;justify-content:center;}
  .chat-headline{display:block;}
  .compact-actions{justify-content:flex-start;margin-top:16px;}
  .feedback-history-page{padding:26px 12px 56px;}
  .history-panel{padding:20px;}
}

/* v32 bypass tipe pengirim */
.bypass-checks{display:grid;gap:6px;min-width:210px}
.mini-check{font-size:12px;margin:0;display:flex;align-items:center;gap:6px;line-height:1.2}
.mini-check input{width:auto;min-width:auto}
.users-bypass-wrap table td{vertical-align:top}
.security-code-field input::placeholder{letter-spacing:1px}
