
:root{
  --cr:#FAFAF7;--cr2:#F2F1EC;--cr3:#E8E6DE;
  --ink:#1C1B18;--ink2:#4A4840;--ink3:#8A8880;--ink4:#C8C6BE;
  --amb:#B5832A;--amb2:#F0DFB8;--amb3:#FBF6EC;
  --sage:#4A7B5C;--sage2:#DFF0E6;
  --rose:#B5463A;--rose2:#FDE8E6;
  --sky:#2D5F8A;--sky2:#E0EEF9;
  --brd:rgba(0,0,0,.07);
  --sh1:0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);
  --sh2:0 4px 12px rgba(0,0,0,.08),0 2px 4px rgba(0,0,0,.04);
  --r1:8px;--r2:12px;--r3:16px;--r4:24px;
  --fd:'Lora',Georgia,serif;--fb:'DM Sans',sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--fb);font-size:14px;color:var(--ink);background:var(--cr);-webkit-font-smoothing:antialiased}

/* ===== MARYO STICKER ANIMATION (V1.6.0) ===== */
.maryo-sticker-img {
  width: 120px;
  height: 120px;
  display: block;
  margin: 8px auto;
  border-radius: 12px;
  animation: maryoStickerPop 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

@keyframes maryoStickerPop {
  0% { transform: scale(0.5) rotate(-5deg); opacity: 0; }
  100% { transform: scale(1) rotate(0deg); opacity: 1; }
}

/* ===== SKELETON UI SHIMMER (V1.5.1) ===== */
.skel {
  background: linear-gradient(
    90deg,
    rgba(0, 0, 0, 0.03) 25%,
    rgba(0, 0, 0, 0.08) 37%,
    rgba(0, 0, 0, 0.03) 63%
  );
  background-size: 400% 100%;
  animation: maryo-shimmer 1.5s ease-in-out infinite;
  position: relative;
  overflow: hidden;
  border-radius: 8px;
}

body.pm .skel {
  background: linear-gradient(
    90deg,
    rgba(255, 255, 255, 0.03) 25%,
    rgba(255, 255, 255, 0.08) 37%,
    rgba(255, 255, 255, 0.03) 63%
  );
  background-size: 400% 100%;
}

@keyframes maryo-shimmer {
  0% { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

.skel-text {
  height: 12px;
  margin-bottom: 8px;
  width: 100%;
  border-radius: 4px;
}
.skel-text.short { width: 60%; }
.skel-text.medium { width: 85%; }

.skel-circle {
  border-radius: 50%;
  width: 40px;
  height: 40px;
  flex-shrink: 0;
}

.skel-balloon {
  border-radius: 18px;
  padding: 16px;
  height: 80px;
  margin-bottom: 12px;
}

.skel-card {
  border-radius: 18px;
  padding: 16px;
  background: rgba(0, 0, 0, 0.02);
  border: 1px solid rgba(0, 0, 0, 0.05);
  margin-bottom: 14px;
}

body.pm .skel-card {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.05);
}



/* PROFİL MODAL */
#profil-screen{display:none;position:fixed;inset:0;background:rgba(28,27,24,.5);backdrop-filter:blur(8px);z-index:200;align-items:flex-end;justify-content:center}
#profil-screen.show{display:flex}
.profil-panel{background:var(--cr);border-radius:24px 24px 0 0;width:100%;max-width:740px;max-height:92vh;overflow-y:auto;padding:0 0 40px}
body.pm .profil-panel{background:#1A1918}
.profil-hdr{position:sticky;top:0;background:var(--cr);border-bottom:1px solid var(--brd);padding:18px 20px 14px;display:flex;align-items:center;gap:12px;z-index:2}
body.pm .profil-hdr{background:#1A1918}
.profil-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--amb),var(--sage));display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-size:20px;font-weight:500;color:#fff;flex-shrink:0}
.profil-body{padding:16px 20px}
.profil-sec{font-size:11px;font-weight:600;color:var(--ink3);letter-spacing:.6px;text-transform:uppercase;margin:18px 0 10px}
.profil-stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px}
.profil-stat{background:#fff;border:1px solid var(--brd);border-radius:12px;padding:12px;text-align:center;box-shadow:var(--sh1)}
body.pm .profil-stat{background:#252420}
.profil-stat-n{font-family:var(--fd);font-size:22px;font-weight:500}
.profil-stat-l{font-size:10px;color:var(--ink3);margin-top:2px}

/* SABAH ÖZETİ */
#sabah-screen{display:none;position:fixed;inset:0;background:var(--cr);z-index:250;overflow-y:auto;padding:0}
#sabah-screen.show{display:flex;flex-direction:column}
.sabah-hero{background:linear-gradient(135deg,var(--ink) 0%,#3A3830 100%);color:#fff;padding:40px 28px 28px;flex-shrink:0}
.sabah-tarih{font-size:13px;color:rgba(255,255,255,.5);margin-bottom:4px;letter-spacing:.3px}
.sabah-baslik{font-family:var(--fd);font-size:26px;font-weight:500;margin-bottom:20px;line-height:1.3}
.sabah-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.sabah-stat{background:rgba(255,255,255,.08);border-radius:12px;padding:14px;text-align:center}
.sabah-stat-n{font-family:var(--fd);font-size:28px;font-weight:500}
.sabah-stat-l{font-size:11px;color:rgba(255,255,255,.5);margin-top:2px}
.sabah-body{padding:20px 20px 100px;flex:1}
.sabah-sec-title{font-size:11px;font-weight:600;color:var(--ink3);letter-spacing:.6px;text-transform:uppercase;margin:20px 0 10px}
.sabah-ders-item{display:flex;align-items:center;gap:12px;padding:12px 14px;background:#fff;border:1px solid var(--brd);border-radius:12px;margin-bottom:8px;box-shadow:var(--sh1)}
.sabah-saat{font-family:var(--fd);font-size:15px;font-weight:500;color:var(--amb);min-width:42px}
.sabah-footer{position:fixed;bottom:0;left:0;right:0;background:rgba(250,250,247,.95);backdrop-filter:blur(10px);border-top:1px solid var(--brd);padding:16px 20px;display:flex;gap:10px}
body.pm #sabah-screen{background:#111110}
body.pm .sabah-body{background:#111110}
body.pm .sabah-ders-item{background:#1C1B18;border-color:rgba(255,255,255,.06)}
body.pm .sabah-footer{background:rgba(17,17,16,.95);border-top-color:rgba(255,255,255,.06)}


.emoji-sab{background:var(--cr2);border:1px solid var(--cr3);border-radius:6px;padding:4px 8px;font-size:16px;cursor:pointer;transition:all .15s}
.emoji-sab:hover{background:var(--amb3);border-color:var(--amb)}
.sablon-btn{background:var(--cr2);border:1px solid var(--cr3);border-radius:20px;padding:4px 10px;font-size:11px;font-family:var(--fb);font-weight:500;cursor:pointer;color:var(--ink2);transition:all .15s;white-space:nowrap}
.sablon-btn:hover{background:var(--amb3);border-color:var(--amb);color:var(--amb)}


/* ARAMA */
#search-panel input:focus{outline:none}
.sr-item{display:flex;align-items:flex-start;gap:10px;padding:10px 14px;cursor:pointer;border-bottom:1px solid var(--cr2);transition:background .1s}
.sr-item:last-child{border-bottom:none}
.sr-item:hover{background:var(--cr2)}
.sr-icon{font-size:18px;flex-shrink:0;margin-top:1px}
.sr-title{font-size:13px;font-weight:500;color:var(--ink)}
.sr-sub{font-size:11px;color:var(--ink3);margin-top:1px}
.sr-badge{font-size:10px;padding:2px 7px;border-radius:10px;margin-left:auto;flex-shrink:0}

/* LOCK */
#lock-screen{display:none;position:fixed;inset:0;background:rgba(17,17,16,.9);backdrop-filter:blur(20px);z-index:300;flex-direction:column;align-items:center;justify-content:center;gap:20px}
#lock-screen.show{display:flex}
.lock-ring{width:80px;height:80px;border-radius:50%;background:rgba(255,255,255,.06);border:1.5px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;font-size:36px;transition:all .3s}
.lock-ring.scan{background:rgba(181,131,42,.12);border-color:rgba(181,131,42,.4);animation:pulse 1.4s infinite}
.lock-ring.ok{background:rgba(74,123,92,.15);border-color:rgba(74,123,92,.5)}
.lock-ring.err{animation:shake .4s}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.04)}}
@keyframes shake{25%{transform:translateX(-6px)}75%{transform:translateX(6px)}}
@keyframes blink-badge {
  0% { opacity: 0.35; }
  100% { opacity: 1; }
}
#lock-title{font-family:var(--fd);font-size:22px;color:rgba(255,255,255,.9);font-weight:500}
#lock-sub{font-size:13px;color:rgba(255,255,255,.4);text-align:center;max-width:220px;line-height:1.6}
#lock-btn{background:var(--amb);color:#111;border:none;border-radius:20px;padding:12px 28px;font-family:var(--fb);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}
#lock-btn:hover{filter:brightness(1.1);transform:translateY(-1px)}

.pin-dot{width:14px;height:14px;border-radius:50%;background:rgba(255,255,255,.2);border:2px solid rgba(255,255,255,.3);transition:all .15s}
.pin-dot.filled{background:var(--amb);border-color:var(--amb)}
.pin-dot.error{background:var(--rose);border-color:var(--rose)}
.pin-key{width:56px;height:56px;border-radius:50%;background:rgba(255,255,255,.1);border:1.5px solid rgba(255,255,255,.15);color:rgba(255,255,255,.9);font-size:20px;font-family:var(--fd);font-weight:500;cursor:pointer;transition:all .1s}
.pin-key:hover{background:rgba(255,255,255,.18)}
.pin-key:active{background:rgba(181,131,42,.3);border-color:rgba(181,131,42,.5);transform:scale(.95)}
#lock-skip{background:none;border:none;color:rgba(255,255,255,.3);font-size:12px;cursor:pointer;font-family:var(--fb);padding:8px}
#lock-skip:hover{color:rgba(255,255,255,.55)}

/* APP */
.app{max-width:1400px;margin:0 auto;padding:16px 16px 40px}
.app-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--brd)}
h1{font-family:var(--fd);font-size:21px;font-weight:500;color:var(--ink);letter-spacing:-.3px}

/* MODE BTN */
#mode-btn{background:var(--cr2);border:1px solid var(--brd);border-radius:20px;padding:6px 14px;font-size:12px;font-family:var(--fb);font-weight:500;cursor:pointer;color:var(--ink2);display:flex;align-items:center;gap:6px;transition:all .2s;white-space:nowrap}
#mode-btn:hover{border-color:var(--amb);color:var(--amb)}

/* TABS */
.tabs{display:flex;gap:2px;margin-bottom:20px;background:var(--cr2);border-radius:var(--r3);padding:4px;flex-wrap:wrap;border:1px solid var(--brd)}
.tab{padding:7px 12px;font-size:12.5px;font-family:var(--fb);font-weight:500;cursor:pointer;border:none;background:transparent;color:var(--ink3);border-radius:var(--r2);transition:all .15s;white-space:nowrap}
.tab:hover{color:var(--ink2);background:rgba(255,255,255,.5)}
.tab.active{color:var(--ink);background:#fff;box-shadow:var(--sh1)}
.tab.atab{position:relative}
.adot{position:absolute;top:5px;right:5px;width:6px;height:6px;background:var(--rose);border-radius:50%;display:none}

/* SECTIONS */
.sec{display:none}
.sec{display:none}.sec.active{display:block}
.personal-sec{display:none}
.personal-sec.active{display:block}

/* CARDS */
.card{background:#fff;border:1px solid var(--brd);border-radius:var(--r3);padding:16px 18px;margin-bottom:12px;box-shadow:var(--sh1)}
.card-title{font-family:var(--fd);font-size:15px;font-weight:500;color:var(--ink);margin-bottom:14px;letter-spacing:-.2px}

/* FORMS */
.fl{display:flex;flex-direction:column;gap:5px;margin-top:12px}
.fl:first-child{margin-top:0}
.fl>label{font-size:11px;font-weight:600;color:var(--ink3);letter-spacing:.5px;text-transform:uppercase}
input,select,textarea{width:100%;font-family:var(--fb);font-size:14px;color:var(--ink);background:var(--cr);border:1.5px solid var(--cr3);border-radius:var(--r1);padding:9px 12px;outline:none;transition:all .15s;-webkit-appearance:none}
input:focus,select:focus,textarea:focus{border-color:var(--amb);background:#fff;box-shadow:0 0 0 3px var(--amb2)}
textarea{min-height:70px;resize:vertical;line-height:1.6}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}

/* BUTTONS */
.btn-p{display:inline-flex;align-items:center;gap:6px;background:var(--ink);color:#fff;border:none;border-radius:var(--r2);padding:10px 18px;font-family:var(--fb);font-size:13px;font-weight:500;cursor:pointer;margin-top:12px;transition:all .15s;letter-spacing:-.1px}
.btn-p:hover{background:var(--ink2);transform:translateY(-1px);box-shadow:var(--sh2)}
.btn-s{display:inline-flex;align-items:center;gap:5px;background:#fff;border:1.5px solid var(--cr3);border-radius:var(--r1);padding:7px 13px;font-family:var(--fb);font-size:12px;font-weight:500;cursor:pointer;color:var(--ink2);transition:all .15s}
.btn-s:hover{border-color:var(--ink4);color:var(--ink)}
.btn-e{background:var(--sky2);border:none;border-radius:var(--r1);padding:5px 10px;font-family:var(--fb);font-size:11px;font-weight:500;cursor:pointer;color:var(--sky)}
.btn-d{background:var(--rose2);border:none;border-radius:var(--r1);padding:5px 10px;font-family:var(--fb);font-size:11px;font-weight:500;cursor:pointer;color:var(--rose)}
.btn-wa{display:inline-flex;align-items:center;gap:6px;background:#25D366;color:#fff;border:none;border-radius:var(--r2);padding:9px 16px;font-family:var(--fb);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;text-decoration:none}
.btn-wa:hover{background:#1ebe59;transform:translateY(-1px)}

/* CHIPS */
.chip{display:inline-block;padding:6px 12px;border-radius:20px;font-size:13px;border:1.5px solid var(--cr3);margin:3px;cursor:pointer;background:#fff;color:var(--ink2);transition:all .15s;font-weight:500}
.chip.sel{background:var(--ink);color:#fff;border-color:var(--ink)}

/* BADGES */
.bdg{display:inline-block;font-size:11px;font-weight:600;padding:3px 8px;border-radius:20px}
.bi{background:var(--sky2);color:var(--sky)}
.bs{background:var(--sage2);color:var(--sage)}
.bw{background:var(--amb3);color:var(--amb)}
.bd{background:var(--rose2);color:var(--rose)}
.bp{background:#EEE8FF;color:#6B48CC}
.bg{background:var(--cr2);color:var(--ink2)}

/* STATS */
.sg{display:grid;grid-template-columns:repeat(auto-fit,minmax(90px,1fr));gap:8px;margin-bottom:12px}
.st{background:#fff;border:1px solid var(--brd);border-radius:var(--r2);padding:12px 14px;box-shadow:var(--sh1)}
.st-l{font-size:10px;font-weight:600;color:var(--ink3);letter-spacing:.3px;text-transform:uppercase}
.st-v{font-family:var(--fd);font-size:22px;font-weight:500;color:var(--ink);margin-top:3px;letter-spacing:-.5px}

/* ROWS */
.row{display:flex;align-items:center;gap:8px;padding:9px 0;border-bottom:1px solid var(--cr2)}
.row:last-child{border-bottom:none}
.loge{border-left:3px solid var(--cr3);padding-left:12px;margin-bottom:12px;transition:border-color .15s}
.loge:hover{border-left-color:var(--amb)}

/* ALERTS */
.alc{border-radius:var(--r2);padding:13px 15px;margin-bottom:9px;border:1px solid;display:flex;gap:10px;align-items:flex-start}
.al-u{background:#FFF5F4;border-color:#F5C5C0}
.al-w{background:#FFFBF0;border-color:#F0D890}
.al-i{background:#F0F7FF;border-color:#B8D8F0}
.al-s{background:#F0FBF4;border-color:#A8E0BC}

/* HOMEWORK */
.hwc{background:#fff;border:1.5px solid var(--cr3);border-radius:var(--r3);padding:14px;margin-bottom:9px;box-shadow:var(--sh1)}
.hwc.hw-ok{border-color:#A8E0BC;background:#F8FFF9}
.hwc.hw-pa{border-color:#F0D890;background:#FFFDF5}
.hwc.hw-no{border-color:#F5C5C0;background:#FFF8F7}
.ret{padding:5px 11px;border-radius:20px;font-size:12px;font-family:var(--fb);font-weight:500;cursor:pointer;border:1.5px solid;transition:all .15s}
.r-ok{background:var(--sage2);border-color:#A8E0BC;color:var(--sage)}
.r-pa{background:var(--amb3);border-color:#F0D890;color:var(--amb)}
.r-no{background:var(--rose2);border-color:#F5C5C0;color:var(--rose)}
.ret.a-ok{background:var(--sage);color:#fff;border-color:var(--sage)}
.ret.a-pa{background:var(--amb);color:#fff;border-color:var(--amb)}
.ret.a-no{background:var(--rose);color:#fff;border-color:var(--rose)}
.pinbtn{display:inline-flex;align-items:center;gap:4px;padding:4px 9px;border-radius:20px;font-size:11px;font-family:var(--fb);font-weight:500;cursor:pointer;border:1.5px solid var(--cr3);background:#fff;color:var(--ink3);transition:all .15s}
.pinbtn.on{background:#EEE8FF;border-color:#C4B4F0;color:#6B48CC}

/* FILTER */
.fbar{display:flex;gap:5px;margin-bottom:12px;flex-wrap:wrap;align-items:center}
.fbar span{font-size:11px;color:var(--ink3);font-weight:500}
.fc{padding:5px 12px;border-radius:20px;font-size:12px;font-family:var(--fb);font-weight:500;border:1.5px solid var(--cr3);cursor:pointer;background:#fff;color:var(--ink3);transition:all .15s}
.fc.on{background:var(--ink);color:#fff;border-color:var(--ink)}

/* CALENDAR */
.cal-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.cal-nav{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.cal-nav h3{font-family:var(--fd);font-size:14px;font-weight:500;flex:1;text-align:center;color:var(--ink)}
.cw{display:flex;min-width:500px}
.tc{width:36px;flex-shrink:0;margin-top:28px}
.tl{height:52px;display:flex;align-items:flex-start;justify-content:flex-end;padding-right:6px;font-size:9px;color:var(--ink4);margin-top:-5px;font-weight:500}
.dg{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));flex:1;border-left:1px solid var(--cr3)}
.dh{height:28px;display:flex;flex-direction:column;align-items:center;justify-content:center;border-right:1px solid var(--cr3);border-bottom:1px solid var(--cr3);background:var(--cr)}
.dn{font-size:9px;color:var(--ink3);font-weight:600;letter-spacing:.4px;text-transform:uppercase}
.dd{font-size:11px;font-weight:600;color:var(--ink2)}
.dd.td{background:var(--amb);color:#fff;border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-size:9px}
.db{position:relative;border-right:1px solid var(--cr2)}
.hl{position:absolute;left:0;right:0;border-top:1px solid var(--cr2);pointer-events:none}
.lb{position:absolute;left:1px;right:1px;border-radius:5px;padding:2px 4px;overflow:hidden;font-size:9px;line-height:1.3;z-index:1}
.lb-b{background:#E0EDFA;border:1px solid #ADC8E8;color:#1A4A70}
.lb-g{background:var(--sage2);border:1px solid #9FD4B0;color:#2A5C3A}
.lb-o{background:var(--amb3);border:1px solid #D4A840;color:#7A5010}
.lb-x{background:var(--cr2);border:1px solid var(--ink4);color:var(--ink3);opacity:.6}
.lb-extra{background:#FFE8D0;border:1px solid #E8A870;color:#7A3800}
.lb b{font-size:9px;font-weight:600;display:block}
.nl{position:absolute;left:0;right:0;border-top:2px solid var(--rose);z-index:3;pointer-events:none}
.ndot{position:absolute;left:-3px;top:-3px;width:7px;height:7px;background:var(--rose);border-radius:50%}
.leg{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px;padding-top:8px;border-top:1px solid var(--cr2)}
.li{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--ink3);font-weight:500}
.ls{width:10px;height:10px;border-radius:3px}

/* REPORT */
.rp{background:#fff;border:1px solid var(--brd);border-radius:var(--r3);padding:26px 30px;font-family:var(--fd);color:var(--ink);box-shadow:var(--sh2)}
.rp-hdr{display:flex;justify-content:space-between;align-items:flex-start;border-bottom:2px solid var(--ink);padding-bottom:14px;margin-bottom:18px}
.rp-logo{width:54px;height:54px;border:1.5px solid var(--cr3);border-radius:var(--r1);display:flex;align-items:center;justify-content:center;font-size:10px;color:var(--ink4);text-align:center;overflow:hidden;cursor:pointer;background:var(--cr)}
.rp-logo img{width:100%;height:100%;object-fit:cover;border-radius:6px}
.rp-ttl{font-size:19px;font-weight:600;outline:none;letter-spacing:-.3px}
.rp-dt{font-size:11px;color:var(--ink3);margin-top:3px}
.rp-sec{font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--ink3);margin:14px 0 7px;padding-bottom:4px;border-bottom:1px solid var(--cr2);font-family:var(--fb)}
.rp-row{display:flex;padding:6px 0;border-bottom:1px solid var(--cr2);gap:10px;align-items:flex-start}
.rp-lbl{font-size:11px;color:var(--ink3);min-width:155px;flex-shrink:0;outline:none;font-family:var(--fb)}
.rp-val{font-size:12px;font-weight:500;flex:1;outline:none;font-family:var(--fb);color:var(--ink)}
.rp-x{background:none;border:none;cursor:pointer;color:var(--ink4);font-size:12px;flex-shrink:0;padding:0 3px}
.rp-x:hover{color:var(--rose)}
.rp-les{display:flex;padding:4px 0;font-size:11px;border-bottom:1px dotted var(--cr2);gap:6px;font-family:var(--fb)}
.rp-foot{margin-top:18px;padding-top:10px;border-top:1px solid var(--cr2);font-size:10px;color:var(--ink4);text-align:center;outline:none;font-family:var(--fb)}
.add-r{width:100%;padding:6px;border:1.5px dashed var(--cr3);border-radius:var(--r1);cursor:pointer;font-size:12px;font-family:var(--fb);color:var(--ink3);background:none;margin-top:5px;display:flex;align-items:center;justify-content:center;gap:4px}
.add-r:hover{border-color:var(--amb);color:var(--amb)}

/* MODAL */
.mbg{display:none;position:fixed;inset:0;background:rgba(28,27,24,.4);backdrop-filter:blur(4px);z-index:100;align-items:center;justify-content:center}
.mbg.open{display:flex}
.modal{background:#fff;border-radius:var(--r4);padding:22px;width:min(440px,94vw);max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px rgba(0,0,0,.12)}
.modal h3{font-family:var(--fd);font-size:16px;font-weight:500;color:var(--ink);margin-bottom:14px}
.mbtns{display:flex;gap:8px;margin-top:14px;justify-content:flex-end}
.sub{margin-top:18px;padding-top:18px;border-top:1px solid var(--cr2)}
.sub-t{font-size:11px;font-weight:600;letter-spacing:.4px;color:var(--ink3);margin-bottom:10px;text-transform:uppercase}

/* PERSONAL MODE */
body.pm{--cr:#111110;--cr2:#1C1B18;--cr3:#272520;--ink:#F0EDE4;--ink2:#C8C4B8;--ink3:#888478;--ink4:#444038;--brd:rgba(255,255,255,.06);background:#111110;color:#F0EDE4}
body.pm .card{background:#1C1B18}
body.pm .modal{background:#1C1B18}
body.pm input,body.pm select,body.pm textarea{background:#272520;border-color:#333028;color:#F0EDE4}
body.pm input:focus,body.pm select:focus,body.pm textarea:focus{border-color:var(--amb);background:#2A2820}
body.pm .tabs{background:#1C1B18;border-color:rgba(255,255,255,.06)}
body.pm .tab.active{background:#272520;color:var(--amb)}
body.pm .chip{background:#1C1B18;border-color:#333028;color:var(--ink2)}
body.pm .chip.sel{background:var(--amb);border-color:var(--amb);color:#111}
body.pm .btn-p{background:var(--amb);color:#111}
body.pm .btn-p:hover{filter:brightness(1.1)}
body.pm .btn-s{background:#1C1B18;border-color:#333028;color:var(--ink2)}
body.pm .st{background:#1C1B18}
body.pm #mode-btn{border-color:var(--amb);color:var(--amb)}
body.pm .fc.on{background:var(--amb);color:#111;border-color:var(--amb)}
body.pm .dh{background:#1C1B18}
body.pm .hl,.db{border-color:var(--cr3)}
body.pm .dg{border-left-color:var(--cr3)}
body.pm .rp{background:#1C1B18}
body.pm .loge{border-left-color:var(--cr3)}
body.pm .hwc{background:#1C1B18;border-color:var(--cr3)}
body.pm .hwc.hw-ok{background:#0D1E12;border-color:#2A5C3A}
body.pm .hwc.hw-pa{background:#1E180A;border-color:#7A5010}
body.pm .hwc.hw-no{background:#1E0D0A;border-color:#7A2E28}
/* Traffic light */
.hw-tl{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px}
.hw-tl.given{background:#FEE2E2;color:#991B1B}
.hw-tl.submitted{background:#FEF9C3;color:#854D0E}
.hw-tl.evaluated{background:#DCFCE7;color:#166534}
body.pm .hw-tl.given{background:#3B0E0E;color:#FCA5A5}
body.pm .hw-tl.submitted{background:#3B2A0A;color:#FDE68A}
body.pm .hw-tl.evaluated{background:#0A2E1A;color:#86EFAC}
/* Student submission in teacher view */
.hw-submit-box{background:#f0f7ff;border:1px solid #bfdbfe;border-radius:8px;padding:8px 10px;margin-top:8px;font-size:12px}
body.pm .hw-submit-box{background:#0a1929;border-color:#1e3a5f}
body.pm .row{border-bottom-color:var(--cr3)}

/* PERSONAL SPECIAL */
.shop-item{display:flex;align-items:center;gap:9px;padding:9px 0;border-bottom:1px solid var(--cr2)}
.shop-item:last-child{border-bottom:none}
.shop-item.done{opacity:.4;text-decoration:line-through}
.shop-check{width:20px;height:20px;border-radius:50%;border:2px solid var(--ink4);cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:11px;transition:all .15s}
.shop-check.checked{background:var(--amb);border-color:var(--amb);color:#fff}
.expense-row{display:flex;align-items:center;gap:9px;padding:9px 0;border-bottom:1px solid var(--cr2)}
.expense-row:last-child{border-bottom:none}
.sport-row{display:flex;align-items:flex-start;gap:9px;padding:9px 0;border-bottom:1px solid var(--cr2)}
.sport-row:last-child{border-bottom:none}

/* HABIT GRID */
.habit-grid{display:grid;grid-template-columns:1fr repeat(7,26px);gap:3px;align-items:center;margin-bottom:5px}
.habit-dot{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;margin:auto;transition:all .15s}

/* NOTE */
.note-card{background:var(--cr);border:1px solid var(--brd);border-radius:var(--r1);padding:10px 12px;margin-bottom:8px;position:relative}
body.pm .note-card{background:#272520}

/* KILO */
.kilo-big{font-family:var(--fd);font-size:32px;font-weight:500;color:var(--ink)}

/* WATER */
.water-num{font-family:var(--fd);font-size:48px;font-weight:500;color:var(--sky);line-height:1}
body.pm .water-num{color:#60A0D0}
.water-bar{height:8px;background:var(--cr3);border-radius:4px;overflow:hidden;margin:8px 0 4px}
.water-fill{height:100%;background:var(--sky);border-radius:4px;transition:width .3s ease}
body.pm .water-fill{background:#60A0D0}

@media(max-width:520px){
  .app{padding:12px 12px 32px}
  .g2,.g3{grid-template-columns:1fr}
  .tab{padding:6px 9px;font-size:11px}
  .cw{min-width:400px}
  h1{font-size:18px}
}


/* ============================================================
   STABIL 34 — cihaz düzeni, masaüstü geniş ekran, mobil kumanda
   ============================================================ */
html{scroll-behavior:smooth}
.safe-note{font-size:11px;color:var(--ink3);line-height:1.55}
.stabil-pill{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--brd);background:var(--cr2);color:var(--ink3);border-radius:999px;padding:5px 10px;font-size:11px;font-weight:600;white-space:nowrap}
.stabil-pill.ok{color:var(--sage);background:var(--sage2)}
.stabil-pill.warn{color:var(--amb);background:var(--amb3)}
body.pm .stabil-pill.ok{background:#0D1E12;color:#A8E0BC}
body.pm .stabil-pill.warn{background:#1E180A;color:#F0D890}
@media (min-width:900px){
  .app{max-width:1120px;padding:22px 24px 56px}
  .tabs{position:sticky;top:8px;z-index:30;backdrop-filter:blur(10px)}
  .app-hdr{position:sticky;top:0;z-index:35;background:rgba(250,250,247,.92);backdrop-filter:blur(10px);padding-top:8px}
  body.pm .app-hdr{background:rgba(17,17,16,.92)}
  .modal{width:min(520px,94vw)}
  #search-results{max-height:520px}
}
@media (min-width:1180px){
  .app{max-width:1360px}
  #tab-gunluk.sec.active{display:grid;grid-template-columns:minmax(430px,520px) minmax(0,1fr);gap:16px;align-items:start}
  #tab-gunluk #hizli-widget{grid-column:1/-1}
  #tab-takvim.sec.active{display:block}
  #tab-takvim .cal-wrap{width:100%}
  #tab-odev.sec.active,#tab-prog.sec.active,#tab-proje.sec.active,#tab-veli.sec.active,#tab-ogrenci.sec.active,#tab-gorev.sec.active,#tab-ozet.sec.active{display:grid;grid-template-columns:minmax(420px,500px) minmax(0,1fr);gap:16px;align-items:start}
  #tab-odev .fbar,#tab-odev .sg,#tab-odev #hwl,#tab-ozet .sg{grid-column:1/-1}
  #tab-p-ev.personal-sec.active,#tab-p-gorev.personal-sec.active,#tab-p-liste.personal-sec.active,#tab-p-butce.personal-sec.active,#tab-p-spor.personal-sec.active,#tab-p-apps.personal-sec.active{display:grid;grid-template-columns:minmax(420px,520px) minmax(0,1fr);gap:16px;align-items:start}
  .cal-wrap{overflow-x:visible}.cw{min-width:0}
}
@media (min-width:1500px){.app{max-width:1480px}}
@media (max-width:720px){
  html,body{height:100%;overflow:hidden;overscroll-behavior:none}
  body{font-size:13px}
  .app{height:100vh;height:100dvh;display:flex;flex-direction:column;padding:0;max-width:100%;overflow:hidden;position:relative}
  .app-hdr{position:relative;flex-shrink:0;background:var(--cr);padding:10px 12px;margin-bottom:0;border-bottom:1px solid var(--brd)}
  body.pm .app-hdr{background:#1A1918}
  h1{font-size:17px}
  .tabs{flex-shrink:0;position:relative;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0;border-radius:0;border-left:0;border-right:0;scrollbar-width:none;padding:6px 28px 6px 10px;background:var(--cr);border-bottom:1px solid var(--brd);top:auto;scroll-snap-type:x proximity;-webkit-mask-image:linear-gradient(to right,#000 calc(100% - 22px),transparent 100%);mask-image:linear-gradient(to right,#000 calc(100% - 22px),transparent 100%)}
  body.pm .tabs{background:#1A1918}
  .tabs::-webkit-scrollbar{display:none}
  .tabs .tab{scroll-snap-align:start}
  #search-panel{flex-shrink:0;padding:0 10px;margin:0!important}
  .sec{display:none}
  .sec.active{display:block;flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:12px 10px 100px;background:var(--cr);min-height:0}
  body.pm .sec.active{background:#111110}
  .personal-sec{display:none}
  .personal-sec.active{display:block;flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:12px 10px 100px;background:var(--cr);min-height:0}
  body.pm .personal-sec.active{background:#111110}
  .cal-nav{position:sticky;top:0;z-index:30;background:rgba(250,250,247,.97);backdrop-filter:blur(10px);margin:-12px -10px 8px;padding:8px 10px;border-bottom:1px solid var(--brd);}
  body.pm .cal-nav{background:rgba(17,17,16,.97)}
  .tab{flex:0 0 auto;padding:7px 10px;font-size:11.5px}
  .card{padding:14px 14px;border-radius:14px}
  .btn-p,.btn-s,.btn-wa{min-height:38px}
  #mode-lbl{display:none}
  #search-toggle span{display:none}
  .stabil-pill{display:none}
  #search-results{position:fixed!important;top:130px!important;left:10px!important;right:10px!important;max-height:60vh!important}
  .rp{padding:18px 16px;overflow-x:auto}
  .profil-panel,#profil-screen>div{max-width:100%!important;border-radius:20px 20px 0 0!important}
}
/* ============================================================
   iPAD PRO 12.9" OPTİMİZASYON
   Portre: 1024px — Landscape: 1366px
   ============================================================ */

/* Tüm iPad aralığı: iOS zoom önleme + dokunma hedefleri */
@media (min-width:768px) and (max-width:1366px){
  input,select,textarea{font-size:16px!important}
  .btn-p,.btn-s,.btn-wa,.btn-e,.btn-d{min-height:44px}
  .sp-done-btn{min-height:44px;min-width:44px}
  .sp-inp{min-height:44px;font-size:17px}
  .tab{min-height:44px}
}

/* iPad Pro 12.9" portre (1024px): iki sütun layout + büyük dokunma */
@media (min-width:1024px) and (max-width:1179px){
  .app{max-width:100%;padding:20px 28px 60px}
  .tab{padding:10px 16px;font-size:13px}
  .card{padding:18px 20px;border-radius:16px}
  .btn-p,.btn-s,.btn-wa,.btn-e,.btn-d{font-size:14px}
  .modal{width:min(640px,88vw)}
  .wb-type-btn{padding:9px 18px;font-size:13px;min-height:42px}
  .sp-ex-add-btn{padding:9px 14px;font-size:13px;min-height:42px}

  /* İki sütun grid — portre modunda da aktif */
  #tab-gunluk.sec.active{display:grid;grid-template-columns:minmax(400px,500px) minmax(0,1fr);gap:16px;align-items:start}
  #tab-gunluk #hizli-widget{grid-column:1/-1}
  #tab-odev.sec.active,#tab-prog.sec.active,#tab-proje.sec.active,#tab-veli.sec.active,#tab-ogrenci.sec.active,#tab-gorev.sec.active,#tab-ozet.sec.active{display:grid;grid-template-columns:minmax(380px,460px) minmax(0,1fr);gap:16px;align-items:start}
  #tab-odev .fbar,#tab-odev .sg,#tab-odev #hwl,#tab-ozet .sg{grid-column:1/-1}
  #tab-p-ev.personal-sec.active,#tab-p-gorev.personal-sec.active,#tab-p-liste.personal-sec.active,#tab-p-butce.personal-sec.active,#tab-p-spor.personal-sec.active,#tab-p-apps.personal-sec.active{display:grid;grid-template-columns:minmax(380px,480px) minmax(0,1fr);gap:16px;align-items:start}
}

/* iPad Pro 12.9" landscape (1366px): zaten 1180px+ kuralı kapsar, genişliği artır */
@media (min-width:1180px) and (max-width:1400px){
  .app{max-width:1340px;padding:22px 32px 60px}
  .tab{padding:10px 18px;font-size:13px}
  .card{padding:18px 20px}
}

@media print{
  .tabs,.app-hdr,#search-panel,.btn-p,.btn-s,.btn-e,.btn-d,.btn-wa,.add-r,.mbg{display:none!important}
  body{background:#fff}.app{max-width:none;padding:0}.card,.rp{box-shadow:none;border-color:#ddd}
}



/* ============================================================
   STABIL 34 — akıllı akış, AI sekmesi, iPhone/iPad/Mac kullanım
   ============================================================ */
.quick-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-bottom:12px}
.quick-tile{background:#fff;border:1px solid var(--brd);border-radius:14px;padding:12px;box-shadow:var(--sh1)}
.quick-tile .qv{font-family:var(--fd);font-size:24px;font-weight:500;line-height:1}.quick-tile .ql{font-size:10px;color:var(--ink3);font-weight:600;letter-spacing:.3px;text-transform:uppercase;margin-top:4px}
.smart-card{background:linear-gradient(135deg,var(--amb3),#fff);border:1px solid var(--amb2);border-radius:18px;padding:14px 16px;margin-bottom:12px;box-shadow:var(--sh1)}
.smart-card.urgent{background:linear-gradient(135deg,#FFF5F4,#fff);border-color:#F5C5C0}.smart-card.ok{background:linear-gradient(135deg,#F0FBF4,#fff);border-color:#A8E0BC}
.smart-row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.smart-actions{display:flex;gap:6px;flex-wrap:wrap}
.big-action{border:none;border-radius:12px;padding:10px 14px;font-family:var(--fb);font-size:13px;font-weight:700;cursor:pointer;min-height:40px}.big-action.ok{background:var(--sage);color:#fff}.big-action.no{background:var(--rose);color:#fff}.big-action.swap{background:var(--sky);color:#fff}.big-action.wait{background:var(--cr2);color:var(--ink2);border:1px solid var(--cr3)}
.day-card{display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;background:#fff;border:1px solid var(--brd);border-radius:14px;padding:12px 13px;margin-bottom:8px;box-shadow:var(--sh1)}
.day-card.pending{border-color:#F0D890;background:#FFFDF5}.day-card.done{border-color:#A8E0BC;background:#F8FFF9}.day-card.absent{border-color:#F5C5C0;background:#FFF8F7}.day-time{font-family:var(--fd);font-size:15px;color:var(--amb);min-width:44px}.day-name{font-size:14px;font-weight:700}.day-sub{font-size:11px;color:var(--ink3);margin-top:2px}.day-actions{display:flex;gap:5px;flex-wrap:wrap;justify-content:flex-end}
.ai-grid{display:grid;grid-template-columns:minmax(320px,420px) minmax(0,1fr);gap:14px;align-items:start}.ai-result{white-space:pre-wrap;line-height:1.65;background:var(--cr);border:1px solid var(--cr3);border-radius:12px;padding:12px;font-size:13px;min-height:110px}.ai-template{display:inline-flex;margin:3px;padding:7px 10px;border:1px solid var(--cr3);border-radius:999px;background:#fff;color:var(--ink2);font-size:12px;font-weight:600;cursor:pointer}.ai-template:hover{border-color:var(--amb);color:var(--amb)}
.ai-msg{display:flex;max-width:85%}.ai-msg span{padding:10px 14px;border-radius:16px;font-size:13px;line-height:1.6;white-space:pre-wrap;word-break:break-word}
.ai-msg-user{align-self:flex-end;margin-left:auto}.ai-msg-user span{background:var(--ink);color:#fff;border-bottom-right-radius:4px}
.ai-msg-bot span{background:var(--cr2);color:var(--ink);border-bottom-left-radius:4px;border:1px solid var(--brd)}
.ai-msg-action span{background:var(--sage2);color:var(--sage);border:1px solid #A8E0BC;border-bottom-left-radius:4px}
body.pm .ai-msg-bot span{background:#252420;border-color:#333028;color:#e8e6de}
.sek-chip{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:500;font-family:var(--fb);cursor:pointer;border:1.5px solid var(--cr3);background:#fff;color:var(--ink2);transition:all .15s;white-space:nowrap}
.sek-chip:hover{background:var(--sky2);border-color:var(--sky);color:var(--sky)}
body.pm .sek-chip{background:#1C1B18;border-color:#333028;color:#c8c6be}
.voice-result{margin-top:8px;background:#fff;border:1px solid var(--cr3);border-radius:10px;padding:10px;font-size:12px;color:var(--ink2);line-height:1.5}.undo-strip{display:flex;align-items:center;justify-content:space-between;gap:10px;background:#FFFDF5;border:1px solid #F0D890;border-radius:12px;padding:9px 11px;margin-top:8px;font-size:12px;color:#7A5010}.mobile-dock{display:none}
body.pm .quick-tile,body.pm .day-card,body.pm .ai-template,body.pm .voice-result{background:#1C1B18;border-color:#333028}body.pm .ai-result{background:#272520;border-color:#333028}body.pm .smart-card{background:linear-gradient(135deg,#1E180A,#1C1B18)}
@media (min-width:1024px) and (max-width:1400px){.quick-grid{grid-template-columns:repeat(4,1fr)}.ai-grid{grid-template-columns:minmax(360px,460px) minmax(0,1fr)}}
@media (max-width:820px){.quick-grid{grid-template-columns:repeat(2,1fr)}.ai-grid{grid-template-columns:1fr}.day-card{grid-template-columns:1fr}.day-time{min-width:0}.day-actions{justify-content:flex-start}.mobile-dock{display:none!important}}
@media (max-width:430px){.quick-grid{grid-template-columns:1fr 1fr}.quick-tile{padding:10px}.quick-tile .qv{font-size:20px}.day-actions button{flex:1}.smart-actions button{flex:1}.modal{width:96vw;padding:18px}}


/* ============================================================
   STABIL 34.1 — iOS/iPadOS tıklama ve görünmez overlay düzeltmesi
   ============================================================ */
html,body{min-height:100%;-webkit-text-size-adjust:100%;touch-action:manipulation;overflow-x:hidden}
button,.tab,.chip,.fc,.btn-p,.btn-s,.btn-e,.btn-d,.btn-wa,.emoji-sab,.sablon-btn,.ret,.pinbtn,.shop-check,.pin-key,.mobile-dock button,[onclick]{touch-action:manipulation;-webkit-tap-highlight-color:rgba(181,131,42,.18);cursor:pointer}
button,input,select,textarea{font:inherit}
button{appearance:none;-webkit-appearance:none}
.app,.tabs,.card,.sec{position:relative}
/* Kapalı katmanların iOS Safari'de dokunuş yakalamasını engelle */
#lock-screen:not(.show),#profil-screen:not(.show),#sabah-screen:not(.show),.mbg:not(.open){pointer-events:none!important;visibility:hidden!important}
#lock-screen.show,#profil-screen.show,#sabah-screen.show,.mbg.open{pointer-events:auto!important;visibility:visible!important}
#search-panel[style*="display: none"],#search-results[style*="display: none"]{pointer-events:none!important;visibility:hidden!important}
.mobile-dock{pointer-events:auto!important;transform:translateZ(0);-webkit-transform:translateZ(0)}
@supports (-webkit-touch-callout:none){
  body{cursor:pointer}
  .app-hdr,.tabs,.mobile-dock{transform:translateZ(0);-webkit-transform:translateZ(0)}
  input,textarea,select{font-size:16px}
}


/* ============================================================
   STABIL 36 — eski sistemi koruyan kişisel 20 modül + test paneli
   ============================================================ */
.command-hero{background:linear-gradient(135deg,var(--ink),#3A3830);color:#fff;border-radius:22px;padding:20px 22px;margin-bottom:14px;position:relative;overflow:hidden;box-shadow:var(--sh2)}
.command-hero:after{content:"";position:absolute;right:-46px;top:-46px;width:150px;height:150px;border-radius:50%;background:rgba(255,255,255,.055)}
.command-hero h2{font-family:var(--fd);font-size:23px;font-weight:500;letter-spacing:-.4px;margin-bottom:6px;position:relative;z-index:1}
.command-hero p{font-size:13px;color:rgba(255,255,255,.66);line-height:1.55;max-width:720px;position:relative;z-index:1}
.command-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;align-items:start}
.command-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}
.command-module{background:#fff;border:1px solid var(--brd);border-radius:18px;padding:15px 16px;box-shadow:var(--sh1);min-height:118px}
.command-module.wide{grid-column:1/-1}.command-module.tall{min-height:220px}
.command-title{display:flex;align-items:center;gap:8px;font-family:var(--fd);font-size:15px;font-weight:500;margin-bottom:10px;letter-spacing:-.2px}
.command-mini{font-size:11px;color:var(--ink3);line-height:1.55}.command-list{display:flex;flex-direction:column;gap:7px;margin-top:8px}
.command-line{display:flex;align-items:center;justify-content:space-between;gap:8px;border:1px solid var(--cr3);background:var(--cr);border-radius:12px;padding:8px 10px;font-size:12px;color:var(--ink2)}
.command-line b{color:var(--ink);font-weight:700}.command-actions{display:flex;gap:7px;flex-wrap:wrap;margin-top:10px}.command-actions .btn-s,.command-actions .btn-p{margin-top:0}
.mood-row{display:grid;grid-template-columns:repeat(5,1fr);gap:6px}.mood-btn{border:1px solid var(--cr3);background:var(--cr);border-radius:12px;padding:9px 5px;cursor:pointer;font-size:18px}.mood-btn.sel{border-color:var(--amb);background:var(--amb3)}
.score-ring{width:78px;height:78px;border-radius:50%;background:conic-gradient(var(--amb) var(--score,0%),var(--cr3) 0);display:flex;align-items:center;justify-content:center;margin:auto;position:relative}.score-ring:before{content:"";position:absolute;inset:8px;background:#fff;border-radius:50%}.score-ring span{position:relative;font-family:var(--fd);font-size:22px;font-weight:500;color:var(--ink)}
.focus-box{display:grid;grid-template-columns:1fr auto;gap:8px}.mini-tag{display:inline-flex;align-items:center;gap:5px;border-radius:999px;padding:4px 9px;background:var(--cr2);color:var(--ink3);font-size:11px;font-weight:600;margin:2px}
.test-ok{color:var(--sage);font-weight:700}.test-bad{color:var(--rose);font-weight:700}.test-log{background:var(--cr);border:1px solid var(--cr3);border-radius:12px;padding:10px;font-size:12px;line-height:1.6;white-space:pre-wrap;max-height:340px;overflow:auto}
body.pm .command-module{background:#1C1B18;border-color:rgba(255,255,255,.06)}body.pm .command-line,body.pm .test-log{background:#272520;border-color:#333028}body.pm .score-ring:before{background:#1C1B18}body.pm .mood-btn{background:#272520;border-color:#333028}body.pm .mood-btn.sel{background:#1E180A;border-color:var(--amb)}
@media (min-width:1180px){#tab-p-komuta.personal-sec.active{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}#tab-p-komuta .command-hero,#tab-p-komuta .command-module.wide{grid-column:1/-1}.command-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.command-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media (max-width:760px){.command-grid,.command-grid.three{grid-template-columns:1fr}.command-module.wide{grid-column:auto}.command-hero{padding:18px}.command-hero h2{font-size:20px}.mood-row{grid-template-columns:repeat(5,1fr)}}

/* ---- WORKOUT BUILDER ---- */
.wb-type-btn{padding:7px 14px;border-radius:20px;border:1.5px solid var(--cr3);background:var(--cr);color:var(--ink3);font-size:12px;font-family:var(--fb);cursor:pointer;transition:all .15s}
.wb-type-btn.active{background:var(--sage);border-color:var(--sage);color:#fff;font-weight:600}
/* Egzersiz kartı */
.sp-ex-card{border:1px solid var(--cr3);border-radius:14px;overflow:hidden;margin-bottom:10px}
.sp-ex-head{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--cr2);border-bottom:1px solid var(--cr3)}
.sp-ex-name{font-size:13px;font-weight:700;letter-spacing:.2px}
/* Set tablosu */
.sp-set-table{width:100%;border-collapse:collapse}
.sp-set-table th{font-size:9px;font-weight:700;letter-spacing:.8px;color:var(--ink3);padding:5px 8px;text-align:center;background:var(--cr)}
.sp-set-row td{padding:5px 4px;text-align:center;border-top:1px solid var(--cr2)}
.sp-set-row.done{background:#edf7f1}
body.pm .sp-set-row.done{background:#1a2e22}
.sp-set-num{font-size:12px;font-weight:600;color:var(--ink3);width:28px}
.sp-set-prev{font-size:11px;color:var(--ink3);min-width:48px}
.sp-inp{width:64px;font-size:18px;font-weight:600;text-align:center;border:1.5px solid var(--cr3);border-radius:8px;padding:6px 4px;background:var(--cr);color:var(--ink);-moz-appearance:textfield}
.sp-inp::-webkit-inner-spin-button,.sp-inp::-webkit-outer-spin-button{-webkit-appearance:none}
.sp-inp:focus{border-color:var(--sage);outline:none}
.sp-done-btn{width:36px;height:36px;border-radius:50%;border:2px solid var(--cr3);background:var(--cr);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;margin:auto;transition:all .15s}
.sp-done-btn.done{background:var(--sage);border-color:var(--sage);color:#fff}
/* Sesli giriş butonu */
.mic-lbl-btn{background:none;border:1px solid var(--cr3);border-radius:8px;font-size:13px;cursor:pointer;padding:2px 8px;color:var(--ink3);transition:all .15s;line-height:1.6;margin-left:auto}
.mic-lbl-btn:hover{background:var(--cr2);color:var(--amb);border-color:var(--amb)}
.mic-lbl-btn.listening{color:#ff3b30;border-color:#ff3b30;animation:pulse .8s infinite}
/* Hızlı egzersiz ekleme */
.sp-ex-add-btn{padding:8px 13px;border-radius:10px;border:1.5px solid var(--cr3);background:var(--cr);color:var(--ink);font-size:12px;font-family:var(--fb);cursor:pointer;transition:all .15s;text-align:left}
.sp-ex-add-btn:active{background:var(--sage2);border-color:var(--sage)}
/* Geçmiş + PR */
.sp-workout-row{border-bottom:1px solid var(--cr2);padding:10px 0}.sp-workout-row:last-child{border-bottom:none}
.sp-ex-line{font-size:11px;color:var(--ink3);margin-top:2px;line-height:1.6}
.pr-row{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px solid var(--cr2);font-size:13px}.pr-row:last-child{border-bottom:none}

/* HF12/HF13 Mobile Tab Bar Clickability and Stacking Context Fixes */
@media (max-width: 767px) {
  .tabs, #work-tabs, #personal-tabs {
    position: relative !important;
    z-index: 100 !important;
    pointer-events: auto !important;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
  .tab, #work-tabs .tab, #personal-tabs .tab {
    touch-action: manipulation;
    -webkit-tap-highlight-color: rgba(0,0,0,0.1);
  }
  #unified-agenda-card {
    position: relative !important;
    z-index: 1 !important;
  }
  .cal-nav {
    position: relative !important;
    z-index: 1 !important;
  }
  #agenda-filters {
    position: relative !important;
    z-index: 1 !important;
  }
}


/* --- Extracted Style Block --- */


  body.locked > *:not(#fb-login-overlay) {
    display: none !important;
  }
  #fb-login-overlay {
    position: fixed;
    inset: 0;
    z-index: 999999;
    background: radial-gradient(circle at center, #1e1e24 0%, #121214 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  }
  #fb-login-overlay[style*="display: none"] {
    pointer-events: none !important;
    visibility: hidden !important;
  }
  .fb-login-card {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 24px;
    padding: 40px 32px;
    width: 100%;
    max-width: 420px;
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.5);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    text-align: center;
    color: white;
  }
  .fb-login-title {
    font-size: 24px;
    font-weight: 800;
    margin-bottom: 8px;
    background: linear-gradient(135deg, #a594ff 0%, #6c5ce7 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
  }
  .fb-login-sub {
    font-size: 13px;
    color: #a1a1aa;
    margin-bottom: 30px;
  }
  .fb-input-group {
    text-align: left;
    margin-bottom: 16px;
  }
  .fb-input-group label {
    display: block;
    font-size: 10px;
    font-weight: 700;
    color: #a1a1aa;
    text-transform: uppercase;
    margin-bottom: 6px;
    letter-spacing: 0.5px;
  }
  .fb-input-group input {
    width: 100%;
    background: rgba(0, 0, 0, 0.25);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 12px;
    padding: 12px 16px;
    color: white;
    font-size: 14px;
    outline: none;
    transition: border-color 0.2s;
  }
  .fb-input-group input:focus {
    border-color: #6c5ce7;
  }
  .fb-btn-primary {
    width: 100%;
    background: linear-gradient(135deg, #8e2de2 0%, #4a00e0 100%);
    border: none;
    border-radius: 12px;
    padding: 14px;
    color: white;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    transition: transform 0.15s, opacity 0.15s;
    margin-top: 10px;
  }
  .fb-btn-primary:active {
    transform: scale(0.98);
  }
  .fb-divider {
    display: flex;
    align-items: center;
    text-align: center;
    color: #52525b;
    font-size: 11px;
    margin: 20px 0;
  }
  .fb-divider::before, .fb-divider::after {
    content: '';
    flex: 1;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  }
  .fb-divider:not(:empty)::before {
    margin-right: .25em;
  }
  .fb-divider:not(:empty)::after {
    margin-left: .25em;
  }
  .fb-btn-google {
    width: 100%;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 12px;
    padding: 12px;
    color: white;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    transition: background 0.2s;
  }
  .fb-btn-google:hover {
    background: rgba(255, 255, 255, 0.08);
  }
  .fb-btn-google img {
    width: 18px;
    height: 18px;
  }
  .fb-log-box {
    margin-top: 16px;
    font-size: 11px;
    color: #ef4444;
    text-align: center;
    min-height: 16px;
  }


/* --- Extracted Style Block --- */


/* AgendaView Beta v0.1 styles — Faz D.8 Hat B */
.agbeta-fab{
  position:fixed; right:14px; bottom:78px; z-index:9990;
  width:54px; height:54px; border-radius:50%;
  background:linear-gradient(135deg,#6366f1,#8b5cf6);
  color:#fff; border:none; cursor:pointer;
  font-size:22px; box-shadow:0 6px 20px rgba(99,102,241,.45);
  display:flex; align-items:center; justify-content:center;
  transition:transform .15s ease;
}
.agbeta-fab:hover{ transform:scale(1.06); }
.agbeta-fab .agbeta-badge{
  position:absolute; top:-4px; right:-4px;
  background:#ef4444; color:#fff; font-size:9px; font-weight:700;
  padding:2px 5px; border-radius:8px;
}
.agbeta-overlay{
  position:fixed; inset:0; z-index:10000;
  background:rgba(15,23,42,.7); backdrop-filter:blur(6px);
  display:none; align-items:stretch; justify-content:center;
}
.agbeta-overlay.open{ display:flex; }
.agbeta-panel{
  background:#0f172a; color:#e2e8f0;
  width:100%; max-width:980px;
  height:100vh;
  display:flex; flex-direction:column;
  overflow:hidden;
}
.agbeta-head{
  display:flex; align-items:center; gap:10px;
  padding:12px 14px; background:#1e293b; border-bottom:1px solid #334155;
}
.agbeta-head .agbeta-title{
  font-size:15px; font-weight:700; flex:0 0 auto;
}
.agbeta-head .agbeta-mode{
  display:flex; background:#0f172a; border-radius:8px; padding:2px; gap:2px;
}
.agbeta-mode button{
  background:transparent; border:none; color:#94a3b8; cursor:pointer;
  padding:5px 10px; font-size:12px; border-radius:6px;
}
.agbeta-mode button.active{ background:#6366f1; color:#fff; }
.agbeta-head .agbeta-nav{
  margin-left:auto; display:flex; gap:6px; align-items:center;
}
.agbeta-nav button{
  background:#334155; border:none; color:#e2e8f0; cursor:pointer;
  width:30px; height:30px; border-radius:6px; font-size:14px;
}
.agbeta-nav .agbeta-range{
  font-size:12px; color:#cbd5e1; padding:0 8px; min-width:120px; text-align:center;
}
.agbeta-close{
  background:#475569; border:none; color:#fff; cursor:pointer;
  width:30px; height:30px; border-radius:6px; font-size:14px; margin-left:4px;
}
.agbeta-body{
  flex:1; overflow:auto; padding:10px 12px;
}
.agbeta-empty{
  padding:30px 14px; text-align:center; color:#64748b; font-size:13px;
}
.agbeta-day{
  margin-bottom:14px; background:#1e293b; border-radius:10px; overflow:hidden;
  border:1px solid #334155;
}
.agbeta-day-head{
  padding:8px 12px; background:#0f172a;
  font-size:12px; font-weight:700; color:#cbd5e1;
  display:flex; align-items:center; gap:8px;
  border-bottom:1px solid #334155;
}
.agbeta-day-head.today{ background:linear-gradient(90deg,#6366f1,#8b5cf6); color:#fff; }
.agbeta-day-count{
  margin-left:auto; background:#334155; color:#cbd5e1;
  font-size:10px; padding:2px 7px; border-radius:8px; font-weight:600;
}
.agbeta-day-head.today .agbeta-day-count{ background:rgba(255,255,255,.25); color:#fff; }
.agbeta-item{
  display:flex; gap:10px; align-items:flex-start;
  padding:9px 12px; border-bottom:1px solid #334155;
  cursor:pointer; transition:background .12s;
}
.agbeta-item:last-child{ border-bottom:none; }
.agbeta-item:hover{ background:#283447; }
.agbeta-time{
  font-size:12px; font-weight:700; color:#cbd5e1;
  min-width:48px; padding-top:1px;
}
.agbeta-time.allday{ color:#64748b; font-size:10px; }
.agbeta-icon{ font-size:16px; line-height:1.1; padding-top:1px; }
.agbeta-body-text{ flex:1; min-width:0; }
.agbeta-title-row{ font-size:13px; font-weight:600; color:#f1f5f9; line-height:1.25; }
.agbeta-sub{ font-size:11px; color:#94a3b8; margin-top:2px; line-height:1.2; }
.agbeta-type{
  font-size:9px; font-weight:700; text-transform:uppercase;
  letter-spacing:.4px; padding:2px 6px; border-radius:5px;
  margin-left:6px; vertical-align:middle;
}
.agbeta-strip{ width:3px; align-self:stretch; border-radius:2px; }
.agbeta-detail{
  background:#1e293b; padding:14px; border-radius:10px;
  border:1px solid #334155; margin:10px 0;
}
.agbeta-detail-row{ font-size:12px; color:#cbd5e1; margin:4px 0; }
.agbeta-detail-row b{ color:#f1f5f9; }
.agbeta-foot{
  padding:8px 12px; background:#1e293b; border-top:1px solid #334155;
  font-size:11px; color:#64748b; display:flex; align-items:center; gap:8px;
}
.agbeta-foot .agbeta-legend{ display:flex; gap:6px; flex-wrap:wrap; }
.agbeta-foot .agbeta-legend span{
  font-size:10px; padding:2px 7px; border-radius:5px;
  color:#fff; font-weight:600;
}
@media(min-width:760px){
  .agbeta-panel{ margin:30px auto; height:calc(100vh - 60px); border-radius:14px; box-shadow:0 20px 60px rgba(0,0,0,.4); }
}
@media(max-width:480px){
  .agbeta-head{ padding:10px; flex-wrap:wrap; gap:6px; }
  .agbeta-head .agbeta-title{ font-size:13px; }
  .agbeta-nav .agbeta-range{ font-size:11px; min-width:90px; }
  .agbeta-fab{ width:50px; height:50px; bottom:72px; right:10px; }
}
