/* ═══ RESET ═══ */
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;user-select:none;}
:root{
--g: cubic-bezier(.25,.46,.45,.94);
--sp: cubic-bezier(.34,1.4,.64,1);
--fast: cubic-bezier(.4,0,.2,1);
--glass-bg: linear-gradient(135deg,rgba(255,255,255,.18),rgba(255,255,255,.06));
--glass-dk: linear-gradient(135deg,rgba(15,15,22,.78),rgba(8,8,14,.68));
--glass-b: rgba(255,255,255,.26);
--glass-sh: 0 8px 32px rgba(0,0,0,.22),inset 0 1.5px 0 rgba(255,255,255,.38),inset 0 -1px 0 rgba(0,0,0,.07);
--glass-blur: blur(44px) saturate(190%);
--r: 13.5px;
}
body{min-height:100vh;display:flex;align-items:center;justify-content:center;gap:32px;
  background:radial-gradient(ellipse 80% 80% at 15% 10%,#1a0438,transparent),
             radial-gradient(ellipse 60% 60% at 85% 80%,#0c1d45,transparent),
             radial-gradient(ellipse 70% 70% at 50% 50%,#08080f,transparent) #050509;
  font-family:-apple-system,BlinkMacSystemFont,'SF Pro Text','SF Pro Display',sans-serif;overflow:hidden;}

/* ═══ FRAME ═══ */
.iphone{position:relative;width:393px;height:852px;border-radius:54px;flex-shrink:0;
  background:linear-gradient(165deg,#2d2d31 0%,#1c1c1f 30%,#141417 70%,#0f0f11 100%);
  box-shadow:0 0 0 .5px rgba(255,255,255,.12),0 0 0 .5px #000 inset,0 0 0 1.5px #1c1c1f,0 0 0 2.5px rgba(255,255,255,.07),0 50px 130px rgba(0,0,0,.95),inset 0 1px 0 rgba(255,255,255,.1);}
/* Left buttons */
.iphone::before{content:'';position:absolute;left:-3.5px;top:134px;width:3.5px;height:28px;
  background:linear-gradient(180deg,#2e2e32,#3c3c40,#2e2e32);border-radius:2px 0 0 2px;
  box-shadow:0 44px 0 #2e2e32,0 88px 0 #2e2e32;}
/* Right button */
.iphone::after{content:'';position:absolute;right:-3.5px;top:168px;width:3.5px;height:76px;
  background:linear-gradient(180deg,#2e2e32,#3c3c40,#2e2e32);border-radius:0 2px 2px 0;}
/* Silent switch */
.btn-silent{position:absolute;left:-4px;top:104px;width:4px;height:22px;border-radius:2px 0 0 2px;
  cursor:pointer;transition:transform .12s;
  background:linear-gradient(180deg,#2e2e32,#3a3a3e,#2e2e32);}
.btn-silent:active,.btn-silent.on{transform:translateY(4px);}
.btn-vol-up,.btn-vol-dn{position:absolute;left:-4px;width:4px;border-radius:2px 0 0 2px;cursor:pointer;
  background:linear-gradient(180deg,#2e2e32,#3a3a3e,#2e2e32);transition:transform .08s;}
.btn-vol-up{top:138px;height:44px;}
.btn-vol-dn{top:191px;height:44px;}
.btn-vol-up:active,.btn-vol-dn:active{transform:translateX(-2px);}
.btn-power{position:absolute;right:-4px;top:168px;width:4px;height:76px;border-radius:0 2px 2px 0;cursor:pointer;
  background:linear-gradient(180deg,#2e2e32,#3a3a3e,#2e2e32);transition:transform .08s;}
.btn-power:active{transform:translateX(2px);}
.screen{position:absolute;inset:0;border-radius:53px;overflow:hidden;background:#000;}

/* ═══ DYNAMIC ISLAND ═══ */
.island{position:absolute;top:11px;left:50%;transform:translateX(-50%);width:122px;height:36px;
  background:#000;border-radius:18px;z-index:2000;display:flex;align-items:center;justify-content:center;gap:10px;
  transition:all .4s var(--sp);cursor:pointer;}
.island.expand{width:280px;height:64px;border-radius:32px;}
.island-cam{width:10px;height:10px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#1a3040,#000);}
.island-ir{width:7px;height:7px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#3a1400,#180a00);}
.island-content{display:none;flex:1;align-items:center;justify-content:space-between;padding:0 12px;color:#fff;}
.island.expand .island-content{display:flex;}
.island.expand .island-cam,.island.expand .island-ir{display:none;}

/* ═══ STATUS BAR ═══ */
.sb{position:absolute;top:0;left:0;right:0;height:58px;display:flex;align-items:flex-end;justify-content:space-between;
  padding:0 26px 10px;z-index:500;pointer-events:none;}
.sb-time{font-size:15px;font-weight:600;letter-spacing:-.4px;}
.sb-right{display:flex;align-items:center;gap:5px;}
.sig{display:flex;align-items:flex-end;gap:1.5px;}
.sig span{background:currentColor;border-radius:1px;width:3px;}
.sig span:nth-child(1){height:4px;} .sig span:nth-child(2){height:7px;} .sig span:nth-child(3){height:10px;}
.sig span:nth-child(4){height:13px;opacity:.3;}
.bat{width:24px;height:12px;border:1.5px solid;border-radius:3px;padding:1.5px;position:relative;}
.bat::after{content:'';position:absolute;right:-4px;top:50%;transform:translateY(-50%);width:2px;height:5px;background:currentColor;border-radius:0 1px 1px 0;}
.bat-f{height:100%;width:78%;background:#34c759;border-radius:1px;}
.sb.light *{color:#fff;}
.sb.dark *{color:#000;}
/* Mute indicator */
.mute-ind{position:absolute;top:14px;right:20px;width:22px;height:22px;border-radius:11px;
  background:rgba(0,0,0,.7);display:none;align-items:center;justify-content:center;font-size:11px;z-index:1500;
  backdrop-filter:blur(10px);}
.mute-ind.show{display:flex;}

/* ═══ HOME INDICATOR ═══ */
.home-ind{position:absolute;bottom:8px;left:50%;transform:translateX(-50%);
  width:134px;height:5px;border-radius:3px;z-index:1500;cursor:pointer;
  background:rgba(255,255,255,.25);transition:background .2s,transform .12s;}
.home-ind:hover{background:rgba(255,255,255,.42);}
.home-ind:active{transform:translateX(-50%) scaleX(.88);}

/* ═══ VOLUME HUD ═══ */
#vol-hud{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:8px;height:140px;
  border-radius:4px;background:rgba(255,255,255,.15);backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,.25);z-index:3000;opacity:0;transition:opacity .3s;pointer-events:none;overflow:hidden;}
#vol-hud.show{opacity:1;}
#vol-fill{position:absolute;bottom:0;left:0;right:0;background:#fff;border-radius:3px;transition:height .15s;}

/* ═══ VIEWS ═══ */
.view{position:absolute;inset:0;opacity:0;pointer-events:none;
  transition:opacity .38s var(--g),transform .38s var(--g);}
.view.active{opacity:1;pointer-events:all;}
.view.slide-out{transform:scale(.94) translateY(8px);opacity:0;}

/* ═══ WALLPAPERS ═══ */
.wp{position:absolute;inset:0;overflow:hidden;}
.wp-base{position:absolute;inset:-15%;transition:background 1s var(--g);}
/* Aurora (default) */
.wp-aurora .wp-base{background:radial-gradient(ellipse 70% 55% at 22% 18%,#cc50c0,transparent),
  radial-gradient(ellipse 55% 65% at 78% 12%,#4050d8,transparent),
  radial-gradient(ellipse 60% 50% at 12% 78%,#00a8f8,transparent),
  radial-gradient(ellipse 55% 60% at 82% 72%,#e05060,transparent),
  radial-gradient(ellipse 80% 80% at 50% 50%,#180828,transparent) #06060e;
  animation:wpa 14s ease-in-out infinite alternate;}
@keyframes wpa{0%{transform:scale(1) rotate(0deg);}50%{transform:scale(1.04) rotate(.8deg);}100%{transform:scale(1.02) rotate(-.6deg);}}
/* Cosmic */
.wp-cosmic .wp-base{background:radial-gradient(ellipse 60% 70% at 30% 30%,#6a0080,transparent),
  radial-gradient(ellipse 55% 50% at 70% 20%,#1a0050,transparent),
  radial-gradient(ellipse 70% 60% at 60% 75%,#003080,transparent),
  radial-gradient(ellipse 50% 50% at 20% 70%,#400040,transparent) #070010;
  animation:wpa 18s ease-in-out infinite alternate;}
/* Horizon (iOS 15 style) */
.wp-horizon .wp-base{background:radial-gradient(ellipse 80% 40% at 50% 100%,#ff8c00,transparent),
  radial-gradient(ellipse 60% 60% at 20% 60%,#ff4080,transparent),
  radial-gradient(ellipse 60% 60% at 80% 40%,#8040ff,transparent),
  radial-gradient(ellipse 100% 50% at 50% 0%,#0020a0,transparent) #050530;
  animation:wpa 16s ease-in-out infinite alternate;}
/* Pride */
.wp-pride .wp-base{background:linear-gradient(180deg,#ff0000 0%,#ff8800 16.7%,#ffff00 33.3%,#00cc00 50%,#0000ff 66.7%,#8800cc 83.3%,#ff00aa 100%);}
/* Midnight */
.wp-midnight .wp-base{background:radial-gradient(ellipse 70% 70% at 30% 30%,#0a1f3a,transparent),
  radial-gradient(ellipse 60% 60% at 70% 70%,#051020,transparent) #020810;
  animation:wpa 20s ease-in-out infinite alternate;}
/* Sand */
.wp-sand .wp-base{background:radial-gradient(ellipse 80% 60% at 40% 60%,#c8965a,transparent),
  radial-gradient(ellipse 60% 70% at 70% 30%,#e8b878,transparent),
  radial-gradient(ellipse 60% 50% at 20% 20%,#a06830,transparent) #a06020;}
/* Bloom */
.wp-bloom .wp-base{background:radial-gradient(ellipse 70% 70% at 25% 25%,#f060a8,transparent),
  radial-gradient(ellipse 60% 60% at 75% 25%,#a040d8,transparent),
  radial-gradient(ellipse 70% 60% at 50% 75%,#f8a0c8,transparent) #c04898;
  animation:wpa 15s ease-in-out infinite alternate;}
/* Solar */
.wp-solar .wp-base{background:radial-gradient(ellipse 70% 50% at 50% 100%,#ffcc00,transparent),
  radial-gradient(ellipse 80% 60% at 30% 60%,#ff6600,transparent),
  radial-gradient(ellipse 60% 70% at 70% 30%,#ff3300,transparent) #1a0800;}
/* Ocean */
.wp-ocean .wp-base{background:radial-gradient(ellipse 70% 60% at 30% 30%,#0080b0,transparent),
  radial-gradient(ellipse 60% 70% at 70% 70%,#005070,transparent),
  radial-gradient(ellipse 80% 50% at 50% 100%,#00c0e8,transparent) #001830;}
/* Clover */
.wp-clover .wp-base{background:radial-gradient(ellipse 70% 70% at 30% 70%,#206040,transparent),
  radial-gradient(ellipse 60% 60% at 70% 30%,#40a050,transparent),
  radial-gradient(ellipse 80% 50% at 50% 0%,#004020,transparent) #0a1a10;}
.wp-noise{position:absolute;inset:0;opacity:.03;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:180px;}

/* ═══ GLASS ═══ */
.glass{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);
  border:1px solid var(--glass-b);box-shadow:var(--glass-sh);}
.glass-dk{background:var(--glass-dk);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);
  border:1px solid rgba(255,255,255,.1);box-shadow:0 8px 32px rgba(0,0,0,.3),inset 0 1px 0 rgba(255,255,255,.12);}
.glass-ul{background:rgba(255,255,255,.07);backdrop-filter:blur(20px) saturate(150%);
  -webkit-backdrop-filter:blur(20px) saturate(150%);border:1px solid rgba(255,255,255,.08);}

/* ═══ LOCK SCREEN ═══ */
#lock .sb{color:#fff;}
#lock .sb *{color:#fff !important;}
.lk-time{position:absolute;top:110px;left:0;right:0;text-align:center;color:#fff;pointer-events:none;}
.lk-big{font-size:82px;font-weight:200;letter-spacing:-5px;line-height:1;}
.lk-date{font-size:18px;font-weight:400;opacity:.8;margin-top:5px;}
/* Lock particles */
.pt{position:absolute;border-radius:50%;background:rgba(255,255,255,.5);pointer-events:none;
  animation:ptf linear infinite;}
@keyframes ptf{0%{transform:translateY(110%) translateX(0);opacity:0;}8%{opacity:.55;}92%{opacity:.2;}100%{transform:translateY(-20px) translateX(12px);opacity:0;}}
/* Lock notifs */
.lk-notifs{position:absolute;top:300px;left:14px;right:14px;display:flex;flex-direction:column;gap:8px;}
.ln{border-radius:20px;padding:13px 15px;display:flex;align-items:flex-start;gap:11px;cursor:pointer;transition:transform .12s;
  background:rgba(255,255,255,.14);backdrop-filter:blur(30px);border:1px solid rgba(255,255,255,.22);}
.ln:active{transform:scale(.975);}
.ln-ico{width:34px;height:34px;border-radius:8px;overflow:hidden;flex-shrink:0;}
.ln-body{flex:1;min-width:0;}
.ln-app{font-size:11px;color:rgba(255,255,255,.5);font-weight:500;letter-spacing:.3px;}
.ln-txt{font-size:14px;color:#fff;font-weight:500;margin-top:2px;line-height:1.3;}
.ln-time{font-size:11px;color:rgba(255,255,255,.35);flex-shrink:0;}
/* Lock shortcuts */
.lk-sc{position:absolute;bottom:50px;left:0;right:0;display:flex;justify-content:space-between;padding:0 38px;}
.lk-btn{width:52px;height:52px;border-radius:26px;display:flex;align-items:center;justify-content:center;font-size:21px;cursor:pointer;
  transition:transform .12s;background:rgba(255,255,255,.14);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.2);}
.lk-btn:active{transform:scale(.88);}
.lk-hint{position:absolute;bottom:24px;left:0;right:0;text-align:center;color:rgba(255,255,255,.45);font-size:12px;font-weight:500;letter-spacing:.2px;}

/* ═══ PASSCODE ═══ */
#passcode{background:rgba(0,0,0,.1);}
.pc-title{position:absolute;top:106px;left:0;right:0;text-align:center;color:#fff;font-size:22px;font-weight:600;}
.pc-dots{position:absolute;top:154px;left:50%;transform:translateX(-50%);display:flex;gap:18px;}
.pc-dot{width:14px;height:14px;border:2px solid rgba(255,255,255,.5);border-radius:50%;transition:all .14s;}
.pc-dot.on{background:#fff;border-color:#fff;transform:scale(1.1);}
@keyframes shake{0%,100%{transform:translateX(0)}20%{transform:translateX(-7px)}40%{transform:translateX(7px)}60%{transform:translateX(-5px)}80%{transform:translateX(4px)}}
.pc-dot.err{animation:shake .38s ease;}
.kpad{position:absolute;bottom:64px;left:0;right:0;display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding:0 44px;}
.kk{aspect-ratio:1;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;
  color:#fff;transition:transform .09s,background .09s;
  background:rgba(255,255,255,.14);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.16);}
.kk:active{transform:scale(.91);background:rgba(255,255,255,.28);}
.kk .kn{font-size:27px;font-weight:300;line-height:1;}
.kk .ks{font-size:9.5px;font-weight:500;letter-spacing:1.6px;opacity:.5;margin-top:2px;}
.kk.empty{background:transparent;border:none;pointer-events:none;}
.kk.del{font-size:16px;font-weight:500;}

/* ═══ HOME SCREEN ═══ */
#home{background:#000;}
.pgwrap{position:absolute;top:0;left:0;right:0;bottom:96px;overflow:hidden;}
.pger{display:flex;height:100%;transition:transform .34s var(--g);will-change:transform;}
.hpg{flex-shrink:0;width:393px;height:100%;padding:62px 8px 10px;overflow:hidden;}
.agrid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px 0;padding:6px 8px;}
/* App icon */
.aico{display:flex;flex-direction:column;align-items:center;gap:5px;cursor:pointer;position:relative;
  -webkit-touch-callout:none;}
.aico-shell{width:60px;height:60px;border-radius:var(--r);overflow:hidden;position:relative;
  box-shadow:0 3px 14px rgba(0,0,0,.35);transition:transform .12s var(--sp),box-shadow .12s;flex-shrink:0;}
.aico:active .aico-shell{transform:scale(.87);box-shadow:0 1px 6px rgba(0,0,0,.4);}
/* iOS 26 glass sheen */
.aico-shell::after{content:'';position:absolute;inset:0;border-radius:var(--r);
  background:linear-gradient(148deg,rgba(255,255,255,.22) 0%,rgba(255,255,255,.04) 44%,transparent 58%);
  pointer-events:none;z-index:2;}
.aico-shell img,.aico-shell svg,.aico-shell .ico-svg{width:100%;height:100%;display:block;object-fit:cover;border-radius:var(--r);}
.aico-label{font-size:11px;color:#fff;text-align:center;font-weight:500;max-width:68px;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-shadow:0 1px 5px rgba(0,0,0,.75);}
/* Badge */
.badge{position:absolute;top:-5px;right:-6px;min-width:18px;height:18px;border-radius:9px;
  background:#ff3b30;color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;
  justify-content:center;padding:0 4px;z-index:5;border:2px solid rgba(0,0,0,.2);box-shadow:0 1px 4px rgba(0,0,0,.3);}
/* Wiggle */
@keyframes wig{0%{transform:rotate(-2.5deg);}100%{transform:rotate(2.5deg);}}
.aico.wig .aico-shell{animation:wig .22s ease-in-out infinite alternate;}
.ico-del{position:absolute;top:-7px;left:-7px;width:21px;height:21px;background:#fff;border-radius:50%;
  display:none;align-items:center;justify-content:center;color:#000;font-size:11px;font-weight:700;
  z-index:10;box-shadow:0 2px 8px rgba(0,0,0,.3);cursor:pointer;}
.aico.wig .ico-del{display:flex;}
/* Widget */
.widget{border-radius:22px;cursor:pointer;overflow:hidden;position:relative;transition:transform .12s;}
.widget:active{transform:scale(.98);}
.w4{grid-column:span 4;}
.w2{grid-column:span 2;aspect-ratio:1;}
/* Page dots */
.pdots{position:absolute;bottom:100px;left:0;right:0;display:flex;justify-content:center;align-items:center;gap:6px;}
.pdot{width:6px;height:6px;border-radius:3px;background:rgba(255,255,255,.28);transition:all .28s;}
.pdot.cur{width:22px;background:rgba(255,255,255,.82);}
/* Dock */
.dock{position:absolute;bottom:12px;left:16px;right:16px;height:82px;border-radius:28px;
  display:flex;align-items:center;justify-content:space-around;padding:0 14px;
  background:linear-gradient(135deg,rgba(255,255,255,.21),rgba(255,255,255,.08));
  backdrop-filter:blur(55px) saturate(210%);-webkit-backdrop-filter:blur(55px) saturate(210%);
  border:1px solid rgba(255,255,255,.32);
  box-shadow:0 8px 44px rgba(0,0,0,.28),inset 0 1.5px 0 rgba(255,255,255,.42),inset 0 -1px 0 rgba(0,0,0,.08);}

/* ═══ APP WINDOWS ═══ */
.awin{position:absolute;inset:0;z-index:400;opacity:0;visibility:hidden;pointer-events:none;
  transform:scale(.93) translateY(32px);
  transform-origin:center 80%;
  transition:opacity .32s cubic-bezier(.25,.46,.45,.94),transform .4s cubic-bezier(.34,1.4,.64,1),visibility .32s;}
.awin.open{opacity:1;visibility:visible;pointer-events:all;transform:scale(1) translateY(0);}
.awin.closing{opacity:0!important;transform:scale(.93) translateY(32px)!important;transition:opacity .22s ease-in,transform .24s ease-in!important;}
.app-hdr{height:58px;display:flex;align-items:flex-end;justify-content:space-between;padding:0 16px 10px;flex-shrink:0;}
.app-title{font-size:17px;font-weight:600;}
.bk{color:#007aff;font-size:15px;cursor:pointer;display:flex;align-items:center;gap:2px;font-weight:400;}
.tab-bar{display:flex;border-bottom:1px solid rgba(0,0,0,.1);flex-shrink:0;}
.tab-btn{flex:1;padding:10px;text-align:center;font-size:13px;color:#8e8e93;cursor:pointer;border-bottom:2px solid transparent;transition:color .18s;}
.tab-btn.on{color:#007aff;border-bottom-color:#007aff;}
.tab-pane{display:none;} .tab-pane.on{display:flex;flex-direction:column;flex:1;overflow:hidden;}
/* List rows */
.lrow{display:flex;align-items:center;padding:11px 16px;border-bottom:1px solid rgba(0,0,0,.06);cursor:pointer;gap:13px;transition:background .1s;}
.lrow:active{background:rgba(0,0,0,.05);}
.lrow:last-child{border-bottom:none;}

/* ─── PHONE ─── */
#a-phone{background:#f2f2f7;display:flex;flex-direction:column;}
.ph-num{font-size:34px;font-weight:200;letter-spacing:3px;text-align:center;min-height:52px;padding:22px 16px 4px;color:#1c1c1e;}
.ph-kpad{padding:0 18px;display:grid;grid-template-columns:repeat(3,1fr);gap:12px;}
.phk{aspect-ratio:1;background:#fff;border-radius:50%;display:flex;flex-direction:column;align-items:center;
  justify-content:center;cursor:pointer;box-shadow:0 2px 6px rgba(0,0,0,.08);transition:transform .09s,background .09s;}
.phk:active{transform:scale(.9);background:#e5e5ea;}
.phk .n{font-size:26px;font-weight:300;color:#1c1c1e;line-height:1;}
.phk .s{font-size:9px;color:#3a3a3c;letter-spacing:2px;margin-top:2px;}
.ph-actions{display:flex;justify-content:center;align-items:center;gap:42px;padding:16px 18px 6px;}
.call-btn{width:68px;height:68px;background:#34c759;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:26px;cursor:pointer;box-shadow:0 4px 20px rgba(52,199,89,.4);border:none;transition:transform .1s;}
.call-btn:active{transform:scale(.92);}
.del-btn{width:48px;height:48px;background:none;border:none;font-size:20px;cursor:pointer;color:#3a3a3c;display:flex;align-items:center;justify-content:center;}
.ph-tabbar{display:flex;background:#f2f2f7;border-top:1px solid #e5e5ea;padding:10px 0 4px;margin-top:auto;}
.ph-tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;cursor:pointer;font-size:20px;}
.ph-tab span{font-size:9.5px;color:#8e8e93;font-weight:400;}
.ph-tab.on{color:#007aff;}
.ph-panel{flex:1;overflow-y:auto;display:none;}
.ph-panel.on{display:flex;flex-direction:column;}
/* Call animation */
#call-screen{position:absolute;inset:0;background:linear-gradient(145deg,#1c1c2e,#2c2c3e);z-index:20;
  display:none;flex-direction:column;align-items:center;justify-content:center;color:#fff;gap:16px;}
#call-screen.show{display:flex;}
.call-av{width:88px;height:88px;border-radius:44px;background:linear-gradient(135deg,#007aff,#5856d6);
  display:flex;align-items:center;justify-content:center;font-size:36px;font-weight:600;}
.call-name{font-size:28px;font-weight:600;}
.call-status{font-size:16px;opacity:.6;}
.call-btns{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:30px;padding:0 30px;}
.call-b{aspect-ratio:1;border-radius:50%;background:rgba(255,255,255,.14);display:flex;flex-direction:column;
  align-items:center;justify-content:center;cursor:pointer;font-size:22px;gap:4px;transition:background .1s;}
.call-b:active{background:rgba(255,255,255,.28);}
.call-b span{font-size:10px;opacity:.55;}
.end-btn{width:72px;height:72px;background:#ff3b30;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;cursor:pointer;}

/* ─── MESSAGES ─── */
#a-msgs{background:#f2f2f7;display:flex;flex-direction:column;}
.msg-list{flex:1;overflow-y:auto;}
.msg-row{display:flex;align-items:center;padding:11px 16px;border-bottom:1px solid rgba(0,0,0,.06);cursor:pointer;gap:12px;background:#fff;transition:background .1s;}
.msg-row:active{background:#f0f0f5;}
.msg-av{width:50px;height:50px;border-radius:25px;display:flex;align-items:center;justify-content:center;
  font-size:18px;font-weight:600;color:#fff;flex-shrink:0;}
.msg-info{flex:1;min-width:0;}
.msg-nm{font-weight:600;font-size:16px;color:#1c1c1e;}
.msg-pr{font-size:14px;color:#8e8e93;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:2px;}
.msg-meta{display:flex;flex-direction:column;align-items:flex-end;gap:5px;flex-shrink:0;}
.msg-tm{font-size:12px;color:#8e8e93;}
.msg-badge{min-width:20px;height:20px;background:#007aff;color:#fff;border-radius:10px;font-size:11px;
  font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 5px;}
/* Chat view */
.chat-v{position:absolute;inset:0;background:#fff;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .3s var(--g);}
.chat-v.open{transform:translateX(0);}
.chat-hdr{background:#f2f2f7;padding:10px 16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid #e5e5ea;flex-shrink:0;padding-top:56px;}
.chat-msgs{flex:1;overflow-y:auto;padding:14px 16px;display:flex;flex-direction:column;gap:4px;}
.bub{max-width:73%;padding:10px 14px;border-radius:20px;font-size:16px;line-height:1.38;word-break:break-word;}
.bub.s{background:#007aff;color:#fff;align-self:flex-end;border-bottom-right-radius:6px;}
.bub.r{background:#e5e5ea;color:#000;align-self:flex-start;border-bottom-left-radius:6px;}
.bub-time{font-size:10px;color:#8e8e93;align-self:flex-end;margin-bottom:4px;}
.typing{display:flex;gap:4px;padding:10px 14px;background:#e5e5ea;border-radius:20px;align-self:flex-start;width:56px;}
.typing span{width:8px;height:8px;background:#8e8e93;border-radius:50%;animation:typ 1.2s infinite;}
.typing span:nth-child(2){animation-delay:.2s;}
.typing span:nth-child(3){animation-delay:.4s;}
@keyframes typ{0%,80%,100%{transform:scale(1);}40%{transform:scale(1.5);}}
.chat-inp{padding:8px 14px;border-top:1px solid #e5e5ea;display:flex;align-items:center;gap:9px;flex-shrink:0;background:#f2f2f7;}
.chat-inp input{flex:1;background:#fff;border:1px solid #e5e5ea;border-radius:22px;padding:9px 14px;font-size:16px;outline:none;font-family:inherit;}
.send-b{width:32px;height:32px;background:#007aff;border-radius:50%;display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:#fff;font-size:14px;border:none;flex-shrink:0;transition:transform .1s;}
.send-b:active{transform:scale(.9);}

/* ─── SAFARI ─── */
#a-safari{background:#f2f2f7;display:flex;flex-direction:column;}
.sf-top{background:#f2f2f7;border-bottom:1px solid #e5e5ea;padding:58px 12px 8px;flex-shrink:0;}
.sf-bar{display:flex;align-items:center;gap:8px;}
.sf-nav{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:18px;color:#007aff;cursor:pointer;border:none;background:none;font-family:inherit;}
.sf-nav:disabled{opacity:.3;}
.sf-url-w{flex:1;background:#fff;border-radius:12px;height:36px;display:flex;align-items:center;padding:0 11px;gap:7px;border:1px solid #e5e5ea;overflow:hidden;}
.sf-url-w input{flex:1;border:none;outline:none;font-size:14.5px;font-family:inherit;text-align:center;min-width:0;color:#1c1c1e;background:transparent;}
.sf-frame-wrap{flex:1;position:relative;overflow:hidden;background:#fff;}
#sf-frame{width:100%;height:100%;border:none;display:block;}
.sf-new-tab{position:absolute;inset:0;background:#f2f2f7;overflow-y:auto;padding:16px;}
.sf-nt-title{font-size:20px;font-weight:700;margin-bottom:14px;color:#1c1c1e;}
.sf-fgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px;}
.sf-fav{display:flex;flex-direction:column;align-items:center;gap:7px;cursor:pointer;}
.sf-fav-ico{width:50px;height:50px;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,.1);display:flex;align-items:center;justify-content:center;font-size:24px;}
.sf-fav-ico img{width:100%;height:100%;object-fit:cover;}
.sf-fav-lbl{font-size:11px;color:#3a3a3c;text-align:center;max-width:56px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.sf-bot{display:flex;justify-content:space-around;align-items:center;padding:8px 16px 12px;background:#f2f2f7;border-top:1px solid #e5e5ea;flex-shrink:0;}
.sf-bot-b{width:38px;height:38px;display:flex;align-items:center;justify-content:center;font-size:18px;color:#007aff;cursor:pointer;border:none;background:none;}
.sf-bot-b:disabled{opacity:.3;}
.sf-loading{position:absolute;bottom:0;left:0;right:0;height:2px;background:#007aff;transform-origin:left;transition:transform .3s;animation:sfload 2s ease-in-out;display:none;}
@keyframes sfload{0%{width:0}70%{width:80%}100%{width:100%}}

/* ─── MAIL ─── */
#a-mail{background:#f2f2f7;display:flex;flex-direction:column;}
.mail-list{flex:1;overflow-y:auto;}
.mail-row{padding:12px 16px;border-bottom:1px solid rgba(0,0,0,.06);cursor:pointer;background:#fff;display:flex;gap:12px;transition:background .1s;}
.mail-row:active{background:#f0f0f5;}
.mail-dot{width:10px;height:10px;border-radius:5px;background:#007aff;flex-shrink:0;margin-top:5px;}
.mail-dot.read{background:transparent;}
.mail-body{flex:1;min-width:0;}
.mail-from{font-size:16px;font-weight:600;color:#1c1c1e;}
.mail-from.read{font-weight:400;}
.mail-sub{font-size:15px;color:#1c1c1e;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:1px;}
.mail-sub.read{color:#8e8e93;font-weight:400;}
.mail-prev{font-size:13px;color:#8e8e93;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:1px;}
.mail-tm{font-size:12px;color:#8e8e93;flex-shrink:0;}
/* Email reader */
.mail-reader{position:absolute;inset:0;background:#fff;transform:translateX(100%);transition:transform .3s var(--g);display:flex;flex-direction:column;}
.mail-reader.open{transform:translateX(0);}
.mail-rd-hdr{padding:58px 16px 12px;border-bottom:1px solid #e5e5ea;flex-shrink:0;}
.mail-rd-subj{font-size:20px;font-weight:700;color:#1c1c1e;line-height:1.3;}
.mail-rd-from{font-size:14px;color:#8e8e93;margin-top:5px;}
.mail-rd-body{flex:1;overflow-y:auto;padding:16px;font-size:16px;line-height:1.6;color:#1c1c1e;}
/* Compose */
.mail-compose{position:absolute;inset:0;background:#fff;transform:translateY(100%);transition:transform .3s var(--g);display:flex;flex-direction:column;}
.mail-compose.open{transform:translateY(0);}
.compose-hdr{padding:14px 16px;border-bottom:1px solid #e5e5ea;display:flex;justify-content:space-between;align-items:center;flex-shrink:0;padding-top:56px;}
.compose-row{padding:12px 16px;border-bottom:1px solid #f0f0f5;display:flex;gap:10px;align-items:flex-start;}
.compose-lbl{color:#8e8e93;font-size:16px;min-width:36px;}
.compose-row input,.compose-row textarea{flex:1;border:none;outline:none;font-size:16px;font-family:inherit;resize:none;}
.compose-body{flex:1;padding:16px;font-size:16px;}
.compose-body textarea{width:100%;height:100%;border:none;outline:none;font-family:inherit;resize:none;font-size:16px;line-height:1.6;}

/* ─── MUSIC ─── */
#a-music{background:#1c1c1e;color:#fff;display:flex;flex-direction:column;}
.mu-tabs{display:flex;background:#1c1c1e;border-bottom:1px solid rgba(255,255,255,.08);}
.mu-tab{flex:1;padding:10px;text-align:center;font-size:13px;color:rgba(255,255,255,.4);cursor:pointer;border-bottom:2px solid transparent;transition:color .18s;}
.mu-tab.on{color:#fc3158;border-bottom-color:#fc3158;}
/* Now Playing */
.mu-np{flex:1;overflow-y:auto;display:flex;flex-direction:column;align-items:center;padding:16px 0 30px;}
.mu-alb{width:260px;aspect-ratio:1;border-radius:18px;margin:8px 0 22px;
  background:linear-gradient(135deg,#667eea,#764ba2);
  display:flex;align-items:center;justify-content:center;font-size:90px;
  box-shadow:0 24px 60px rgba(0,0,0,.6);transition:transform .2s var(--sp);}
.mu-alb.small{transform:scale(.88);}
.mu-np-info{width:100%;padding:0 28px;display:flex;justify-content:space-between;align-items:flex-start;}
.mu-np-tit{font-size:22px;font-weight:700;color:#fff;} .mu-np-art{font-size:16px;color:#8e8e93;margin-top:3px;}
.mu-prog{width:calc(100% - 56px);margin:16px 0 6px;}
.mu-bar{height:4px;background:rgba(255,255,255,.18);border-radius:2px;cursor:pointer;position:relative;}
.mu-f{height:100%;background:#fff;border-radius:2px;transition:width .5s linear;}
.mu-times{display:flex;justify-content:space-between;font-size:11px;color:rgba(255,255,255,.4);margin-top:5px;}
.mu-ctrls{display:flex;align-items:center;justify-content:space-around;width:100%;padding:4px 0;}
.mub{background:none;border:none;color:#fff;cursor:pointer;font-size:28px;padding:10px;transition:opacity .1s;}
.mub:active{opacity:.5;}
.mub.play{font-size:52px;}
.mu-vrow{display:flex;align-items:center;gap:10px;width:calc(100% - 56px);margin-top:4px;}
.mu-vrow span{font-size:16px;}
input[type=range].slider{flex:1;height:4px;background:rgba(255,255,255,.2);border-radius:2px;outline:none;}
input[type=range].slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;background:#fff;border-radius:50%;cursor:pointer;}
/* Library */
.mu-lib{flex:1;overflow-y:auto;}
.mu-lib-row{display:flex;align-items:center;padding:10px 16px;border-bottom:1px solid rgba(255,255,255,.07);cursor:pointer;gap:14px;transition:background .1s;}
.mu-lib-row:active{background:rgba(255,255,255,.05);}
.mu-th{width:46px;height:46px;border-radius:8px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:22px;overflow:hidden;}
.mu-th img{width:100%;height:100%;object-fit:cover;}

/* ─── CAMERA ─── */
#a-cam{background:#000;display:flex;flex-direction:column;}
.cam-vf{flex:1;position:relative;overflow:hidden;background:#0a1020;}
.cam-grid{position:absolute;inset:0;pointer-events:none;}
.cam-grid::before,.cam-grid::after{content:'';position:absolute;background:rgba(255,255,255,.1);}
.cam-grid::before{left:33.3%;right:33.3%;top:0;bottom:0;border-left:1px solid rgba(255,255,255,.1);border-right:1px solid rgba(255,255,255,.1);}
.cam-grid::after{top:33.3%;bottom:33.3%;left:0;right:0;border-top:1px solid rgba(255,255,255,.1);border-bottom:1px solid rgba(255,255,255,.1);}
.cam-af{position:absolute;width:70px;height:70px;border:2px solid #ffd60a;top:50%;left:50%;transform:translate(-50%,-50%);
  border-radius:4px;box-shadow:0 0 0 1px rgba(0,0,0,.3);animation:afp .5s ease;}
@keyframes afp{0%{opacity:0;transform:translate(-50%,-50%) scale(1.3);}100%{opacity:1;transform:translate(-50%,-50%) scale(1);}}
.cam-modes{display:flex;justify-content:center;gap:20px;padding:8px 0;background:#000;flex-shrink:0;}
.cam-mode{font-size:12px;color:rgba(255,255,255,.45);cursor:pointer;font-weight:500;transition:color .18s;padding:4px 2px;}
.cam-mode.on{color:#ffd60a;}
.cam-bot{display:flex;align-items:center;justify-content:space-around;padding:18px 28px 28px;background:#000;flex-shrink:0;}
.cam-lib-btn{width:54px;height:54px;border-radius:10px;overflow:hidden;background:#2c2c2e;display:flex;align-items:center;justify-content:center;cursor:pointer;}
.shutter{width:76px;height:76px;border-radius:50%;border:4px solid #fff;padding:3px;cursor:pointer;transition:transform .1s;}
.shutter-inner{width:100%;height:100%;background:#fff;border-radius:50%;transition:transform .08s;}
.shutter:active .shutter-inner{transform:scale(.88);}
.cam-flip{width:54px;height:54px;border-radius:50%;background:rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;font-size:22px;cursor:pointer;transition:transform .3s;}
.cam-top{display:flex;justify-content:space-around;align-items:center;padding:58px 16px 10px;background:#000;flex-shrink:0;}
.cam-top-btn{font-size:20px;cursor:pointer;color:#ffd60a;width:36px;height:36px;display:flex;align-items:center;justify-content:center;}
/* Flash animation */
@keyframes flash{0%{opacity:0;}20%{opacity:1;}100%{opacity:0;}}

/* ─── PHOTOS ─── */
#a-photos{background:#fff;display:flex;flex-direction:column;}
.ph-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;}
.ph-th{aspect-ratio:1;cursor:pointer;overflow:hidden;display:flex;align-items:center;justify-content:center;
  font-size:30px;transition:transform .1s;}
.ph-th:active{transform:scale(.95);}
.ph-viewer{position:absolute;inset:0;background:#000;display:flex;flex-direction:column;transform:scale(.88);opacity:0;pointer-events:none;transition:all .28s var(--sp);}
.ph-viewer.open{transform:scale(1);opacity:1;pointer-events:all;}
.ph-full{flex:1;display:flex;align-items:center;justify-content:center;font-size:120px;}
.ph-viewer-hdr{position:absolute;top:0;left:0;right:0;padding:58px 16px 12px;display:flex;justify-content:space-between;background:linear-gradient(to bottom,rgba(0,0,0,.6),transparent);}

/* ─── MAPS ─── */
#a-maps{display:flex;flex-direction:column;background:#e8e0d5;}
.map-canvas{flex:1;position:relative;overflow:hidden;cursor:grab;}
.map-canvas:active{cursor:grabbing;}
.map-bg{position:absolute;inset:0;background:#e8e0d5;transition:transform .3s var(--g);}
/* Road system */
.mr{position:absolute;background:#fff;}
.mr.main{background:#fcc846;}
.mr.h{left:0;right:0;}
.mr.v{top:0;bottom:0;}
.mblock{position:absolute;background:#d5cfc8;border-radius:3px;}
.mpark{position:absolute;background:#a9d4a3;border-radius:6px;}
.mwater{position:absolute;background:#9ecae1;border-radius:5px;}
.mpin{position:absolute;font-size:38px;transform:translate(-50%,-100%);cursor:pointer;z-index:5;
  filter:drop-shadow(0 3px 6px rgba(0,0,0,.35));animation:pin-drop .4s var(--sp);}
@keyframes pin-drop{0%{transform:translate(-50%,-120%);}60%{transform:translate(-50%,-88%);}100%{transform:translate(-50%,-100%);}}
.map-search-bar{position:absolute;top:68px;left:14px;right:14px;z-index:10;
  background:#fff;border-radius:14px;height:44px;display:flex;align-items:center;padding:0 14px;gap:10px;
  box-shadow:0 4px 20px rgba(0,0,0,.18);font-size:15px;color:#8e8e93;cursor:pointer;}
.map-btns-r{position:absolute;right:14px;bottom:16px;display:flex;flex-direction:column;gap:8px;z-index:10;}
.map-btn{width:44px;height:44px;background:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;
  font-size:18px;cursor:pointer;box-shadow:0 2px 10px rgba(0,0,0,.16);transition:transform .1s;}
.map-btn:active{transform:scale(.92);}
.map-card{position:absolute;bottom:0;left:0;right:0;background:#fff;border-radius:22px 22px 0 0;
  padding:16px 18px 38px;box-shadow:0 -4px 20px rgba(0,0,0,.1);transform:translateY(100%);transition:transform .3s var(--sp);}
.map-card.show{transform:translateY(0);}
.mc-handle{width:40px;height:4px;background:#d1d1d6;border-radius:2px;margin:0 auto 14px;}
.mc-title{font-size:22px;font-weight:700;} .mc-sub{font-size:14px;color:#8e8e93;margin-top:4px;}
.mc-btns{display:flex;gap:10px;margin-top:14px;}
.mc-btn{flex:1;padding:12px;text-align:center;border-radius:12px;font-weight:600;font-size:14px;cursor:pointer;transition:transform .1s;}
.mc-btn:active{transform:scale(.96);}

/* ─── WEATHER ─── */
#a-wx{display:flex;flex-direction:column;overflow-y:auto;position:relative;}
.wx-grad{position:absolute;inset:0;z-index:0;transition:background 1s;}
.wx-body{position:relative;z-index:1;padding-bottom:30px;}
.wx-top{text-align:center;padding:78px 22px 16px;color:#fff;}
.wx-city{font-size:32px;font-weight:400;}
.wx-sub{font-size:14px;opacity:.65;margin-top:2px;}
.wx-big{font-size:96px;font-weight:100;letter-spacing:-6px;line-height:1;margin:6px 0;}
.wx-cond{font-size:20px;opacity:.85;}
.wx-hl{font-size:16px;opacity:.6;margin-top:4px;}
.wx-card{margin:0 16px 14px;border-radius:18px;overflow:hidden;background:rgba(0,0,0,.2);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.15);}
.wx-card-hdr{padding:9px 16px;font-size:11px;font-weight:600;letter-spacing:.5px;color:rgba(255,255,255,.6);border-bottom:1px solid rgba(255,255,255,.1);}
.wx-hourly{display:flex;gap:16px;overflow-x:auto;padding:12px 16px;scrollbar-width:none;}
.wx-hourly::-webkit-scrollbar{display:none;}
.wx-hi{display:flex;flex-direction:column;align-items:center;gap:6px;flex-shrink:0;}
.wx-hi-t{font-size:12px;color:rgba(255,255,255,.7);}
.wx-hi-i{font-size:22px;}
.wx-hi-v{font-size:15px;font-weight:500;color:#fff;}
.wx-day{display:flex;align-items:center;padding:10px 16px;border-bottom:1px solid rgba(255,255,255,.08);color:#fff;}
.wx-day:last-child{border-bottom:none;}
.wx-day-nm{width:80px;font-size:16px;}
.wx-day-i{font-size:22px;flex:1;text-align:center;}
.wx-day-lo{opacity:.6;font-size:16px;margin-right:6px;}
.wx-day-hi{font-size:16px;font-weight:500;}
/* City list */
.wx-cities{padding:0 16px 20px;}
.wx-city-card{border-radius:18px;padding:16px;margin-bottom:12px;cursor:pointer;
  background:rgba(0,0,0,.2);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.15);
  display:flex;justify-content:space-between;align-items:flex-end;color:#fff;transition:transform .1s;}
.wx-city-card:active{transform:scale(.98);}

/* ─── NOTES ─── */
#a-notes{background:#f2f2f7;display:flex;flex-direction:column;}
.note-list{flex:1;overflow-y:auto;}
.note-row{background:#fff;padding:13px 16px;border-bottom:1px solid rgba(0,0,0,.06);cursor:pointer;transition:background .1s;}
.note-row:active{background:#f0f0f5;}
.note-nm{font-size:16px;font-weight:600;color:#1c1c1e;}
.note-pr{font-size:13px;color:#8e8e93;margin-top:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.note-dt{font-size:11px;color:#c7c7cc;margin-top:3px;}
.note-ed{position:absolute;inset:0;background:#fff;transform:translateX(100%);transition:transform .3s var(--g);display:flex;flex-direction:column;}
.note-ed.open{transform:translateX(0);}
.note-ed-hdr{padding:58px 16px 10px;border-bottom:1px solid #e5e5ea;display:flex;justify-content:space-between;flex-shrink:0;}
.note-format{display:flex;gap:16px;padding:10px 16px;border-bottom:1px solid #e5e5ea;overflow-x:auto;flex-shrink:0;scrollbar-width:none;}
.nfmt{font-size:17px;cursor:pointer;color:#007aff;min-width:28px;text-align:center;transition:transform .1s;}
.nfmt:active{transform:scale(.88);}
.note-ed-body{flex:1;display:flex;flex-direction:column;}
.note-ed-body input{padding:14px 16px;font-size:21px;font-weight:700;border:none;outline:none;font-family:inherit;}
.note-ed-body textarea{flex:1;padding:0 16px 16px;border:none;outline:none;resize:none;font-size:16px;line-height:1.65;font-family:inherit;color:#1c1c1e;}

/* ─── CLOCK ─── */
#a-clock{background:#1c1c1e;color:#fff;display:flex;flex-direction:column;}
.clk-tabs{display:flex;background:#1c1c1e;border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0;overflow-x:auto;}
.clk-tab{padding:11px 16px;font-size:14px;color:rgba(255,255,255,.4);cursor:pointer;border-bottom:2px solid transparent;flex-shrink:0;transition:color .18s;}
.clk-tab.on{color:#ff9f0a;border-bottom-color:#ff9f0a;}
.clk-body{flex:1;overflow-y:auto;display:flex;flex-direction:column;}
/* World clock */
.wc-list{flex:1;overflow-y:auto;}
.wc-row{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.08);}
.wc-city{font-size:18px;} .wc-tz{font-size:12px;opacity:.45;margin-top:3px;}
.wc-time{font-size:38px;font-weight:200;letter-spacing:-2px;}
/* Analog */
.analog{width:200px;height:200px;border-radius:50%;border:2.5px solid rgba(255,255,255,.1);position:relative;background:#2c2c2e;margin:20px auto 10px;box-shadow:0 0 40px rgba(0,0,0,.5);}
.hand{position:absolute;bottom:50%;left:50%;transform-origin:bottom center;border-radius:2px;}
.hand.h{width:6px;height:56px;background:#fff;margin-left:-3px;border-radius:3px 3px 0 0;}
.hand.m{width:4px;height:74px;background:#fff;margin-left:-2px;border-radius:3px 3px 0 0;}
.hand.s{width:2px;height:84px;background:#ff3b30;margin-left:-1px;}
.hand.s::before{content:'';position:absolute;top:-8px;left:-3px;width:8px;height:8px;background:#ff3b30;border-radius:50%;}
.ckctr{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:10px;height:10px;background:#ff3b30;border-radius:50%;z-index:10;}
/* Stopwatch */
.sw-display{text-align:center;padding:30px 0 20px;}
.sw-time{font-size:72px;font-weight:100;letter-spacing:-3px;line-height:1;}
.sw-ms{font-size:36px;font-weight:100;opacity:.6;}
.sw-btns{display:flex;justify-content:space-around;padding:0 40px 20px;}
.sw-btn{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600;cursor:pointer;transition:transform .1s;}
.sw-btn:active{transform:scale(.92);}
.sw-laps{flex:1;overflow-y:auto;padding:0 16px;}
.sw-lap{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.08);font-size:16px;}
/* Alarm */
.alm-list{flex:1;overflow-y:auto;}
.alm-row{display:flex;align-items:center;padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.08);gap:14px;}
.alm-time{font-size:46px;font-weight:200;letter-spacing:-2px;flex:1;}
.alm-ampm{font-size:18px;opacity:.7;align-self:flex-end;margin-bottom:8px;}
.alm-lbl{font-size:12px;opacity:.5;}
.alm-tog{width:51px;height:31px;border-radius:16px;position:relative;cursor:pointer;transition:background .22s;flex-shrink:0;}
.alm-tog.on{background:#34c759;}
.alm-tog.off{background:#3a3a3c;}
.alm-tog::after{content:'';position:absolute;top:2px;left:2px;width:27px;height:27px;background:#fff;border-radius:50%;box-shadow:0 2px 5px rgba(0,0,0,.25);transition:transform .22s;}
.alm-tog.on::after{transform:translateX(20px);}
/* Timer */
.tmr-picker{display:flex;justify-content:center;gap:0;padding:20px;flex-shrink:0;}
.tmr-col{display:flex;flex-direction:column;align-items:center;width:80px;overflow:hidden;height:180px;position:relative;}
.tmr-col-vals{display:flex;flex-direction:column;align-items:center;transition:transform .15s;}
.tmr-val{height:36px;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:200;cursor:pointer;width:80px;}
.tmr-val.sel{font-size:32px;font-weight:300;}
.tmr-col-lbl{font-size:14px;opacity:.5;margin-top:5px;}
.tmr-display{text-align:center;padding:30px 0 20px;font-size:72px;font-weight:100;letter-spacing:-3px;}
.tmr-arc{width:200px;height:200px;margin:0 auto;position:relative;}
.tmr-arc svg{transform:rotate(-90deg);}
.tmr-btns{display:flex;justify-content:space-around;padding:0 40px 20px;}

/* ─── CALCULATOR ─── */
#a-calc{background:#000;display:flex;flex-direction:column;}
.calc-disp{flex:1;display:flex;flex-direction:column;justify-content:flex-end;padding:16px 22px 4px;min-height:180px;}
.calc-prev{font-size:22px;color:rgba(255,255,255,.35);text-align:right;min-height:28px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.calc-cur{font-size:72px;font-weight:200;letter-spacing:-4px;line-height:1.1;color:#fff;text-align:right;overflow:hidden;text-overflow:ellipsis;cursor:ew-resize;transition:font-size .1s;}
.calc-btns{padding:6px 14px 6px;display:grid;grid-template-columns:repeat(4,1fr);gap:10px;}
.cb{aspect-ratio:1;border-radius:50%;border:none;font-size:26px;font-weight:400;cursor:pointer;transition:opacity .1s,transform .08s;font-family:inherit;display:flex;align-items:center;justify-content:center;}
.cb:active{opacity:.62;transform:scale(.92);}
.cb.fn{background:#a5a5a5;color:#000;}
.cb.op{background:#ff9f0a;color:#fff;font-size:30px;}
.cb.op.active{background:#fff;color:#ff9f0a;}
.cb.nm{background:#333;color:#fff;}
.cb.zero{border-radius:34px;grid-column:span 2;aspect-ratio:auto;padding:0 28px;justify-content:flex-start;font-size:26px;}

/* ─── SETTINGS ─── */
#a-set{background:#f2f2f7;display:flex;flex-direction:column;}
.set-sc{flex:1;overflow-y:auto;padding-bottom:30px;}
.set-profile{margin:16px;background:#fff;border-radius:16px;padding:15px;display:flex;gap:14px;align-items:center;cursor:pointer;box-shadow:0 1px 3px rgba(0,0,0,.05);}
.set-av{width:64px;height:64px;border-radius:32px;background:linear-gradient(135deg,#007aff,#0040c8);display:flex;align-items:center;justify-content:center;font-size:26px;color:#fff;font-weight:600;flex-shrink:0;}
.set-sec{margin:0 16px 20px;}
.set-sec-lbl{font-size:12px;color:#6d6d72;font-weight:500;letter-spacing:.4px;text-transform:uppercase;padding:0 6px;margin-bottom:8px;}
.set-lst{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.05);}
.set-row{display:flex;align-items:center;padding:11px 16px;gap:12px;border-bottom:1px solid rgba(0,0,0,.05);cursor:pointer;transition:background .1s;}
.set-row:last-child{border-bottom:none;}
.set-row:active{background:#f0f0f5;}
.set-ico{width:29px;height:29px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;}
.set-lbl{flex:1;font-size:16px;color:#1c1c1e;}
.set-val{font-size:14px;color:#8e8e93;}
.set-chev{color:#c7c7cc;font-size:16px;}
.tog{width:51px;height:31px;border-radius:16px;position:relative;cursor:pointer;transition:background .22s;flex-shrink:0;}
.tog.on{background:#34c759;}
.tog.off{background:#e5e5ea;}
.tog::after{content:'';position:absolute;top:2px;left:2px;width:27px;height:27px;background:#fff;border-radius:50%;box-shadow:0 2px 5px rgba(0,0,0,.2);transition:transform .22s;}
.tog.on::after{transform:translateX(20px);}
/* Sub pages */
.set-page{position:absolute;inset:0;background:#f2f2f7;transform:translateX(100%);transition:transform .3s var(--g);display:flex;flex-direction:column;z-index:10;}
.set-page.open{transform:translateX(0);}
/* Wallpaper picker */
.wp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:16px;}
.wp-thumb{aspect-ratio:.5;border-radius:14px;overflow:hidden;cursor:pointer;position:relative;border:3px solid transparent;transition:all .18s;box-shadow:0 3px 12px rgba(0,0,0,.15);}
.wp-thumb.sel{border-color:#007aff;}
.wp-thumb-inner{position:absolute;inset:-10%;animation:wpa 14s ease-in-out infinite alternate;}
.wp-lbl{text-align:center;font-size:11px;color:#8e8e93;margin-top:6px;}

/* ─── HEALTH ─── */
#a-health{background:#f2f2f7;display:flex;flex-direction:column;}
.hlth-sc{flex:1;overflow-y:auto;padding:0 16px 30px;}
.act-rings{background:#fff;border-radius:18px;padding:18px;margin-top:16px;margin-bottom:14px;display:flex;gap:18px;align-items:center;box-shadow:0 1px 4px rgba(0,0,0,.06);}
.ring-leg{flex:1;}
.ring-leg-row{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:14px;}
.ring-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;}
.hlth-card{background:#fff;border-radius:14px;padding:14px;margin-bottom:10px;box-shadow:0 1px 3px rgba(0,0,0,.05);}
.hlth-val{font-size:28px;font-weight:700;margin-bottom:3px;}
.hlth-lbl{font-size:12px;color:#8e8e93;margin-bottom:5px;font-weight:500;}
.hlth-unit{font-size:12px;color:#8e8e93;}
.hlth-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}

/* ─── WALLET ─── */
#a-wallet{background:#1c1c1e;color:#fff;display:flex;flex-direction:column;}
.wallet-sc{flex:1;overflow-y:auto;padding:0 18px 30px;}
.card-stack{position:relative;height:280px;margin:16px 0;}
.wcard{position:absolute;width:100%;height:200px;border-radius:18px;padding:22px;
  display:flex;flex-direction:column;justify-content:space-between;cursor:pointer;
  box-shadow:0 12px 40px rgba(0,0,0,.45);transition:all .3s var(--sp);}
.wcard-num{font-size:16px;letter-spacing:3px;opacity:.85;}
.wcard-row{display:flex;justify-content:space-between;align-items:flex-end;}
.wcard-nm{font-size:13px;opacity:.7;}
.wcard-logo{font-size:30px;}
.apay-btn{background:#fff;color:#000;border-radius:14px;padding:14px;text-align:center;font-size:18px;font-weight:600;cursor:pointer;margin-bottom:18px;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .1s;}
.apay-btn:active{background:#e5e5ea;}
.wtx-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.07);}
.wtx-name{font-size:16px;}
.wtx-amt{font-size:16px;font-weight:600;}

/* ─── FACETIME ─── */
#a-facetime{background:#1c1c1e;color:#fff;display:flex;flex-direction:column;}
/* ─── REMINDERS ─── */
#a-remind{background:#f2f2f7;display:flex;flex-direction:column;}
.rm-list{flex:1;overflow-y:auto;padding:0 16px 16px;}
.rm-smart{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:16px 0;}
.rm-smart-card{background:#fff;border-radius:14px;padding:14px;cursor:pointer;box-shadow:0 1px 3px rgba(0,0,0,.05);transition:transform .1s;}
.rm-smart-card:active{transform:scale(.97);}
.rm-smart-ico{font-size:26px;margin-bottom:8px;}
.rm-smart-nm{font-size:15px;font-weight:600;color:#1c1c1e;}
.rm-smart-cnt{font-size:22px;font-weight:700;float:right;margin-top:-26px;}
.rm-row{background:#fff;border-radius:12px;padding:12px 14px;margin-bottom:8px;display:flex;align-items:flex-start;gap:12px;cursor:pointer;transition:background .1s;}
.rm-row:active{background:#f5f5f5;}
.rm-check{width:22px;height:22px;border-radius:50%;border:2px solid #007aff;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .18s;margin-top:1px;}
.rm-check.done{background:#007aff;border-color:#007aff;}
.rm-check.done::after{content:'✓';color:#fff;font-size:13px;font-weight:700;}
.rm-text{flex:1;font-size:16px;color:#1c1c1e;}
.rm-text.done{text-decoration:line-through;color:#8e8e93;}
.rm-due{font-size:12px;color:#ff3b30;margin-top:2px;}

/* ─── PODCASTS ─── */
#a-pod{background:#f2f2f7;display:flex;flex-direction:column;}
/* ─── TV ─── */
#a-tv{background:#1c1c1e;color:#fff;display:flex;flex-direction:column;}
/* ─── APP STORE ─── */
#a-store{background:#f2f2f7;display:flex;flex-direction:column;}
/* ─── FILES ─── */
#a-files{background:#f2f2f7;display:flex;flex-direction:column;}
/* ─── BOOKS ─── */
#a-books{background:#f2f2f7;display:flex;flex-direction:column;}
/* ─── NEWS ─── */
#a-news{background:#f2f2f7;display:flex;flex-direction:column;}
/* ─── SHORTCUTS ─── */
#a-shortcuts{display:flex;flex-direction:column;}

/* Generic app inner styles */
.app-scroll{flex:1;overflow-y:auto;}
.sec-hdr{padding:16px 16px 8px;font-size:22px;font-weight:700;color:#1c1c1e;}
.sec-hdr.wh{color:#fff;}
.card-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:0 16px 16px;}
.app-card{background:#fff;border-radius:14px;overflow:hidden;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.07);transition:transform .12s;}
.app-card:active{transform:scale(.97);}
.app-card-art{width:100%;aspect-ratio:1.6;object-fit:cover;display:flex;align-items:center;justify-content:center;font-size:44px;}
.app-card-info{padding:10px 12px 12px;}
.app-card-nm{font-size:15px;font-weight:600;color:#1c1c1e;}
.app-card-sub{font-size:12px;color:#8e8e93;margin-top:2px;}

/* ═══ OVERLAYS ═══ */
/* Notification Center */
#nc{position:absolute;top:-110%;left:0;right:0;bottom:0;z-index:800;visibility:hidden;
  transition:top .38s var(--g),visibility .38s;}
#nc.open{top:0;visibility:visible;}
.nc-bg{position:absolute;inset:0;background:rgba(0,0,0,.38);backdrop-filter:blur(32px) saturate(150%);-webkit-backdrop-filter:blur(32px) saturate(150%);}
.nc-body{position:absolute;top:0;left:0;right:0;max-height:100%;overflow-y:auto;padding:68px 16px 20px;}
.nc-sec{font-size:11px;color:rgba(255,255,255,.45);font-weight:600;letter-spacing:.6px;text-transform:uppercase;margin-bottom:8px;padding-left:4px;}
.nc-card{border-radius:18px;padding:13px 15px;margin-bottom:9px;display:flex;align-items:flex-start;gap:11px;cursor:pointer;transition:transform .14s;
  background:rgba(255,255,255,.14);backdrop-filter:blur(30px);border:1px solid rgba(255,255,255,.2);}
.nc-card:active{transform:scale(.98);}
.nc-card-ico{width:34px;height:34px;border-radius:8px;overflow:hidden;flex-shrink:0;}
.nc-app{font-size:11px;color:rgba(255,255,255,.5);font-weight:500;}
.nc-title{font-size:14px;color:#fff;font-weight:600;margin-top:2px;}
.nc-msg{font-size:13px;color:rgba(255,255,255,.65);margin-top:2px;line-height:1.35;}
.nc-time{font-size:11px;color:rgba(255,255,255,.3);flex-shrink:0;}

/* Control Center */
#ccwrap{position:absolute;inset:0;z-index:900;opacity:0;visibility:hidden;transition:opacity .28s,visibility .28s;
  background:rgba(0,0,0,.2);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);}
#ccwrap.open{opacity:1;visibility:visible;}
.cc-panel{position:absolute;top:-500px;right:10px;width:344px;border-radius:28px;padding:18px;
  transition:top .38s var(--sp);
  background:linear-gradient(145deg,rgba(14,14,20,.94),rgba(8,8,14,.9));
  backdrop-filter:blur(65px) saturate(200%);-webkit-backdrop-filter:blur(65px) saturate(200%);
  border:1px solid rgba(255,255,255,.1);box-shadow:0 24px 70px rgba(0,0,0,.55),inset 0 1px 0 rgba(255,255,255,.12);}
.cc-panel.open{top:68px;}
.cc-tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:12px;}
.cc-tile{border-radius:16px;aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer;
  font-size:20px;transition:transform .1s;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.06);}
.cc-tile:active{transform:scale(.89);}
.cc-tile.on{background:rgba(255,255,255,.88);color:#000;}
.cc-tile span{font-size:9px;color:rgba(255,255,255,.5);font-weight:600;letter-spacing:.2px;}
.cc-tile.on span{color:rgba(0,0,0,.5);}
.cc-srow{display:flex;align-items:center;gap:10px;margin-bottom:12px;}
.cc-srow-ico{font-size:16px;}
.cc-row2{display:flex;gap:10px;}
.cc-tile-wide{flex:1;border-radius:16px;padding:12px;display:flex;align-items:center;gap:11px;cursor:pointer;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.06);font-size:20px;transition:transform .1s;}
.cc-tile-wide:active{transform:scale(.96);}
.cc-tile-wide span{font-size:11px;color:rgba(255,255,255,.55);}
.cc-now-playing{margin-top:12px;border-radius:16px;padding:14px;display:flex;align-items:center;gap:12px;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.06);}
.cc-np-art{width:44px;height:44px;border-radius:8px;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;}
.cc-np-info{flex:1;min-width:0;}
.cc-np-tit{font-size:14px;font-weight:600;color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.cc-np-art-nm{font-size:12px;color:rgba(255,255,255,.5);}
.cc-np-ctrls{display:flex;gap:12px;font-size:18px;color:#fff;}
.cc-np-ctrls span{cursor:pointer;transition:opacity .1s;}
.cc-np-ctrls span:active{opacity:.5;}

/* App Switcher */
#switcher{position:absolute;inset:0;z-index:700;opacity:0;visibility:hidden;
  transition:opacity .28s,visibility .28s;
  background:rgba(0,0,0,.58);backdrop-filter:blur(38px) saturate(160%);-webkit-backdrop-filter:blur(38px) saturate(160%);}
#switcher.open{opacity:1;visibility:visible;}
.sw-lbl{padding:74px 0 16px;text-align:center;color:rgba(255,255,255,.4);font-size:12px;font-weight:600;letter-spacing:.7px;text-transform:uppercase;}
.sw-scroll{display:flex;align-items:flex-start;gap:14px;padding:0 28px;overflow-x:auto;scrollbar-width:none;padding-bottom:40px;}
.sw-scroll::-webkit-scrollbar{display:none;}
.sw-card{flex-shrink:0;width:185px;cursor:pointer;}
.sw-preview{width:185px;height:330px;border-radius:18px;overflow:hidden;border:1px solid rgba(255,255,255,.08);box-shadow:0 14px 44px rgba(0,0,0,.5);transition:transform .22s;position:relative;background:#1c1c1e;}
.sw-card:hover .sw-preview{transform:scale(1.025);}
.sw-app-name{color:#fff;font-size:13px;font-weight:500;text-align:center;margin-top:9px;}
.sw-close{position:absolute;top:-8px;right:-8px;width:24px;height:24px;background:#3a3a3c;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px;font-weight:600;z-index:5;transition:background .1s;}
.sw-close:hover{background:#555;}

/* Spotlight */
#spot{position:absolute;inset:0;z-index:600;opacity:0;visibility:hidden;transition:opacity .22s,visibility .22s;
  background:rgba(0,0,0,.62);backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);}
#spot.open{opacity:1;visibility:visible;}
.spot-inner{padding:68px 16px 16px;}
.spot-bar{background:rgba(255,255,255,.13);border-radius:14px;height:46px;display:flex;align-items:center;padding:0 14px;gap:10px;border:1px solid rgba(255,255,255,.18);}
.spot-bar input{flex:1;background:transparent;border:none;outline:none;color:#fff;font-size:17px;font-family:inherit;}
.spot-bar input::placeholder{color:rgba(255,255,255,.4);}
.spot-res{margin-top:12px;}
.spot-item{display:flex;align-items:center;gap:13px;padding:11px 13px;border-radius:15px;margin-bottom:6px;cursor:pointer;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.06);transition:background .1s;}
.spot-item:active{background:rgba(255,255,255,.18);}
.spot-ico{width:44px;height:44px;border-radius:10px;overflow:hidden;flex-shrink:0;}
.spot-nm{color:#fff;font-size:17px;font-weight:500;}
.spot-cat{font-size:12px;color:rgba(255,255,255,.45);margin-top:2px;}

/* Siri */
#siri{position:absolute;inset:0;z-index:1000;opacity:0;visibility:hidden;
  transition:opacity .28s,visibility .28s;
  display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding-bottom:40px;
  background:rgba(0,0,0,.68);backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);}
#siri.open{opacity:1;visibility:visible;}
.siri-orb{width:88px;height:88px;border-radius:50%;margin-bottom:22px;position:relative;
  background:conic-gradient(from 0deg,#ff2d55,#5856d6,#007aff,#30d158,#ff9f0a,#ff2d55);
  animation:spin 2.5s linear infinite;box-shadow:0 0 44px rgba(88,86,214,.5);}
.siri-orb::after{content:'';position:absolute;inset:12%;border-radius:50%;background:rgba(0,0,0,.55);backdrop-filter:blur(8px);}
@keyframes spin{to{filter:hue-rotate(360deg);}}
.siri-bubble{background:rgba(255,255,255,.13);border-radius:22px;padding:14px 20px;margin-bottom:22px;max-width:320px;text-align:center;color:#fff;font-size:17px;line-height:1.45;min-height:48px;border:1px solid rgba(255,255,255,.2);}
.siri-inp-row{display:flex;gap:10px;width:100%;padding:0 18px;}
.siri-inp{flex:1;background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.22);border-radius:26px;padding:13px 18px;color:#fff;font-size:16px;outline:none;font-family:inherit;}
.siri-inp::placeholder{color:rgba(255,255,255,.35);}
.siri-send{width:48px;height:48px;background:#007aff;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;cursor:pointer;border:none;font-size:18px;flex-shrink:0;transition:transform .1s;}
.siri-send:active{transform:scale(.92);}

/* Power menu */
#power-menu{position:absolute;inset:0;z-index:2000;background:rgba(0,0,0,.7);backdrop-filter:blur(30px);
  display:none;flex-direction:column;align-items:center;justify-content:center;gap:30px;}
#power-menu.show{display:flex;}
.pwr-slider{width:280px;background:rgba(255,255,255,.12);border-radius:20px;padding:18px 22px;border:1px solid rgba(255,255,255,.2);}
.pwr-lbl{color:rgba(255,255,255,.6);font-size:13px;font-weight:600;letter-spacing:.4px;text-align:center;margin-bottom:14px;}
.pwr-track{height:60px;background:rgba(255,255,255,.18);border-radius:30px;position:relative;overflow:hidden;cursor:pointer;}
.pwr-thumb{width:60px;height:60px;background:#fff;border-radius:30px;display:flex;align-items:center;justify-content:center;font-size:26px;position:absolute;top:0;left:0;transition:left .15s;}
.pwr-cancel{color:#fff;font-size:17px;cursor:pointer;padding:14px 28px;background:rgba(255,255,255,.12);border-radius:20px;border:1px solid rgba(255,255,255,.2);}

/* Toast notifications */
.toast{position:absolute;top:20px;left:50%;transform:translateX(-50%) translateY(-80px);z-index:3000;
  background:rgba(0,0,0,.8);color:#fff;padding:10px 18px;border-radius:20px;font-size:14px;font-weight:500;
  white-space:nowrap;transition:transform .3s var(--sp);pointer-events:none;backdrop-filter:blur(20px);}
.toast.show{transform:translateX(-50%) translateY(0);}

/* Helpers */
.flex{display:flex;}
.col{flex-direction:column;}
.f1{flex:1;}
.ov{overflow-y:auto;}
.hidden{display:none;}
.wh{color:#fff;}
.gr{color:#8e8e93;}
.scroll{overflow-y:auto;}
.scroll::-webkit-scrollbar{display:none;}


.ph-tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;cursor:pointer;font-size:22px;color:#8e8e93;transition:color .15s;}
.ph-tab span{font-size:9.5px;font-weight:400;}
.ph-tab.on{color:#007aff;}
.phk{aspect-ratio:1;background:#fff;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 6px rgba(0,0,0,.08);transition:transform .09s,background .09s;}
.phk:active{transform:scale(.9);background:#e5e5ea;}
.phk .n{font-size:26px;font-weight:300;color:#1c1c1e;line-height:1;}
.phk .s{font-size:9px;color:#3a3a3c;letter-spacing:2px;margin-top:2px;}
.call-btn{width:68px;height:68px;background:#34c759;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:26px;cursor:pointer;box-shadow:0 4px 20px rgba(52,199,89,.4);border:none;transition:transform .1s;}
.call-btn:active{transform:scale(.92);}
.mu-tab{flex:1;padding:10px;text-align:center;font-size:13px;color:rgba(255,255,255,.4);cursor:pointer;border-bottom:2px solid transparent;transition:color .18s;}
.cam-mode{font-size:12px;color:rgba(255,255,255,.45);cursor:pointer;font-weight:500;padding:4px 2px;white-space:nowrap;}
.cam-mode.on{color:#ffd60a;}
.nc-card{border-radius:18px;padding:13px 15px;margin-bottom:9px;display:flex;align-items:flex-start;gap:11px;cursor:pointer;transition:transform .14s,opacity .3s;background:rgba(255,255,255,.14);backdrop-filter:blur(30px);border:1px solid rgba(255,255,255,.2);}
.nc-card:active{transform:scale(.98);}
.nc-ico{width:34px;height:34px;border-radius:8px;overflow:hidden;flex-shrink:0;}
.nc-app{font-size:11px;color:rgba(255,255,255,.5);font-weight:500;}
.nc-title{font-size:14px;color:#fff;font-weight:600;margin-top:2px;}
.nc-msg{font-size:13px;color:rgba(255,255,255,.65);margin-top:2px;line-height:1.35;}
.nc-time{font-size:11px;color:rgba(255,255,255,.3);flex-shrink:0;}
#nc{position:absolute;inset:0;z-index:800;transform:translateY(-110%);transition:transform .42s cubic-bezier(.25,.46,.45,.94);}
#nc.open{transform:translateY(0);}
#volHud{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:7px;height:140px;border-radius:4px;background:rgba(255,255,255,.15);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.25);z-index:3000;opacity:0;transition:opacity .3s;pointer-events:none;overflow:hidden;}
#volHud.show{opacity:1;}
#volFill{position:absolute;bottom:0;left:0;right:0;background:#fff;border-radius:3px;transition:height .15s;}
.lk-time{position:absolute;top:108px;left:0;right:0;text-align:center;color:#fff;pointer-events:none;}
.lk-big{font-size:82px;font-weight:200;letter-spacing:-5px;line-height:1;}
.lk-date{font-size:18px;font-weight:400;opacity:.82;margin-top:5px;}
.pc-title{position:absolute;top:104px;left:0;right:0;text-align:center;color:#fff;font-size:22px;font-weight:600;}
.pc-dots{position:absolute;top:152px;left:50%;transform:translateX(-50%);display:flex;gap:18px;}
.pc-dot{width:14px;height:14px;border:2px solid rgba(255,255,255,.5);border-radius:50%;transition:all .14s;}
.pc-dot.on{background:#fff;border-color:#fff;}
.kpad{position:absolute;bottom:64px;left:0;right:0;display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding:0 44px;}
.kk{aspect-ratio:1;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;color:#fff;transition:transform .09s,background .09s;background:rgba(255,255,255,.14);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.16);}
.kk:active{transform:scale(.91);background:rgba(255,255,255,.28);}
.kk .kn{font-size:27px;font-weight:300;line-height:1;}
.kk .ks{font-size:9.5px;font-weight:500;letter-spacing:1.6px;opacity:.5;margin-top:2px;}
.kk.empty{background:transparent;border:none;pointer-events:none;}
.bk{color:#007aff;font-size:15px;cursor:pointer;display:flex;align-items:center;gap:2px;}
.lrow{display:flex;align-items:center;padding:11px 16px;border-bottom:1px solid rgba(0,0,0,.06);cursor:pointer;gap:13px;transition:background .1s;}
.lrow:last-child{border-bottom:none;}
.lrow:active{background:rgba(0,0,0,.05);}
.msg-row{display:flex;align-items:center;padding:11px 16px;border-bottom:1px solid rgba(0,0,0,.06);cursor:pointer;gap:12px;background:#fff;transition:background .1s;}
.msg-row:active{background:#f0f0f5;}
.msg-av{width:50px;height:50px;border-radius:25px;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:600;color:#fff;flex-shrink:0;}
.msg-nm{font-weight:600;font-size:16px;color:#1c1c1e;}
.msg-pr{font-size:14px;color:#8e8e93;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:2px;}
.msg-tm{font-size:12px;color:#8e8e93;}
.msg-badge{min-width:20px;height:20px;background:#007aff;color:#fff;border-radius:10px;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 5px;}
.bub{max-width:73%;padding:10px 14px;border-radius:20px;font-size:16px;line-height:1.38;word-break:break-word;}
.bub.s{background:#007aff;color:#fff;align-self:flex-end;border-bottom-right-radius:6px;}
.bub.r{background:#e5e5ea;color:#000;align-self:flex-start;border-bottom-left-radius:6px;}
.typing{display:flex;gap:4px;padding:10px 14px;background:#e5e5ea;border-radius:20px;border-bottom-left-radius:6px;align-self:flex-start;width:56px;}
.typing span{width:7px;height:7px;background:#8e8e93;border-radius:50%;animation:typ 1.2s infinite;}
.typing span:nth-child(2){animation-delay:.2s;}
.typing span:nth-child(3){animation-delay:.4s;}
@keyframes typ{0%,80%,100%{transform:scale(1);}40%{transform:scale(1.5);}}
.send-b{width:32px;height:32px;background:#007aff;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;font-size:13px;border:none;flex-shrink:0;transition:transform .1s;}
.send-b:active{transform:scale(.9);}
.sf-nav{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:20px;color:#007aff;cursor:pointer;border:none;background:none;font-family:inherit;transition:opacity .1s;}
.sf-nav:disabled{opacity:.28;pointer-events:none;}
.mail-row{padding:12px 16px;border-bottom:1px solid rgba(0,0,0,.06);cursor:pointer;background:#fff;display:flex;gap:12px;transition:background .1s;}
.mail-row:active{background:#f0f0f5;}
.set-row{display:flex;align-items:center;padding:11px 16px;gap:12px;border-bottom:1px solid rgba(0,0,0,.05);cursor:pointer;transition:background .1s;}
.set-row:last-child{border-bottom:none;}
.set-row:active{background:#f0f0f5;}
.set-ico{width:29px;height:29px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;}
.set-lbl{flex:1;font-size:16px;color:#1c1c1e;}
.set-val{font-size:14px;color:#8e8e93;}
.set-chev{color:#c7c7cc;font-size:16px;}
.tog{width:51px;height:31px;border-radius:16px;position:relative;cursor:pointer;transition:background .22s;flex-shrink:0;}
.tog.on{background:#34c759;}
.tog.off{background:#e5e5ea;}
.tog::after{content:'';position:absolute;top:2px;left:2px;width:27px;height:27px;background:#fff;border-radius:50%;box-shadow:0 2px 5px rgba(0,0,0,.2);transition:transform .22s;}
.tog.on::after{transform:translateX(20px);}
.clk-tab{padding:11px 16px;font-size:14px;color:rgba(255,255,255,.4);cursor:pointer;border-bottom:2px solid transparent;flex-shrink:0;transition:color .18s;}
.rm-chk{width:22px;height:22px;border-radius:50%;border:2px solid #007aff;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .18s;margin-top:1px;cursor:pointer;}
.chat-v{position:absolute;inset:0;background:#fff;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .3s cubic-bezier(.25,.46,.45,.94);}
.chat-v.open{transform:translateX(0);}
.chat-msgs{flex:1;overflow-y:auto;padding:14px 16px;display:flex;flex-direction:column;gap:4px;}
.note-row{background:#fff;padding:13px 16px;border-bottom:1px solid rgba(0,0,0,.06);cursor:pointer;transition:background .1s;}
.note-row:active{background:#f0f0f5;}
.note-nm{font-size:16px;font-weight:600;color:#1c1c1e;}
.note-pr{font-size:13px;color:#8e8e93;margin-top:3px;}
.note-dt{font-size:11px;color:#c7c7cc;margin-top:3px;}
.cb{aspect-ratio:1;border-radius:50%;border:none;font-size:26px;font-weight:400;cursor:pointer;transition:opacity .1s,transform .08s;font-family:inherit;display:flex;align-items:center;justify-content:center;}
.cb:active{opacity:.62;transform:scale(.92);}
.cb.fn{background:#a5a5a5;color:#000;}
.cb.op{background:#ff9f0a;color:#fff;font-size:30px;}
.cb.op.active{background:#fff;color:#ff9f0a;}
.cb.nm{background:#333;color:#fff;}
.sw-card{flex-shrink:0;width:188px;cursor:pointer;}
.sw-prev{width:188px;height:335px;border-radius:18px;overflow:hidden;border:1px solid rgba(255,255,255,.08);box-shadow:0 14px 44px rgba(0,0,0,.5);transition:transform .22s;position:relative;background:#1c1c1e;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;}
.sw-card:hover .sw-prev{transform:scale(1.025);}
.sw-app-nm{color:#fff;font-size:13px;font-weight:500;text-align:center;margin-top:9px;}
.sw-close-btn{position:absolute;top:-8px;right:-8px;width:24px;height:24px;background:#3a3a3c;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:700;z-index:5;}
.spot-item{display:flex;align-items:center;gap:13px;padding:11px 13px;border-radius:15px;margin-bottom:6px;cursor:pointer;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.06);transition:background .1s;}
.spot-item:active{background:rgba(255,255,255,.18);}
.spot-ico{width:44px;height:44px;border-radius:10px;overflow:hidden;flex-shrink:0;}
.spot-nm{color:#fff;font-size:17px;font-weight:500;}
.spot-cat{font-size:12px;color:rgba(255,255,255,.45);margin-top:2px;}
.cc-tile{border-radius:16px;aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer;font-size:20px;transition:transform .1s;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.06);}
.cc-tile:active{transform:scale(.89);}
.cc-tile.on{background:rgba(255,255,255,.88);color:#000;}
.cc-tile span{font-size:9px;color:rgba(255,255,255,.5);font-weight:600;}
.cc-tile.on span{color:rgba(0,0,0,.5);}
@keyframes spin{to{filter:hue-rotate(360deg);}}


/* ═══ FULL iOS SPRING ANIMATIONS ═══ */
:root{--sp2:cubic-bezier(.34,1.56,.64,1);--sp3:cubic-bezier(.34,1.2,.64,1);--eo:cubic-bezier(.25,.46,.45,.94);}

/* Icons */
.aico{cursor:pointer;-webkit-tap-highlight-color:transparent;}
.aico-shell{transition:transform .12s var(--sp2),box-shadow .12s;}
.aico:active .aico-shell,.aico.pressed .aico-shell{transform:scale(.86);box-shadow:0 1px 8px rgba(0,0,0,.25);}
.aico-svg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:inherit;}
.aico-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:inherit;opacity:0;transition:opacity .5s ease;}
.aico-img.loaded{opacity:1;}
.aico-sheen{position:absolute;inset:0;border-radius:inherit;background:linear-gradient(148deg,rgba(255,255,255,.22) 0%,rgba(255,255,255,.05) 45%,rgba(0,0,0,.06) 100%);pointer-events:none;z-index:3;}
.ico-del{z-index:10;}

/* Wiggle */
@keyframes wig{0%{transform:rotate(-2.5deg) translateY(-1px);}100%{transform:rotate(2.5deg) translateY(1px);}}
.aico.wig .aico-shell{animation:wig .2s ease-in-out infinite alternate;}

/* Icon stagger entrance */
@keyframes icoIn{0%{opacity:0;transform:scale(.55) translateY(20px);}100%{opacity:1;transform:none;}}
@keyframes icoOut{to{opacity:0;transform:scale(.4);}}

/* Notification center - slide from top */
#nc{transform:translateY(-110%);transition:transform .42s var(--eo);visibility:visible;opacity:1;top:0!important;}
#nc.open{transform:translateY(0);}
#ncBg{opacity:0;transition:opacity .42s;}
#nc.open #ncBg{opacity:1;}

/* Control center - slide from bottom right */
#ccwrap{opacity:0;visibility:hidden;transition:opacity .25s var(--eo),visibility .25s;}
#ccwrap.open{opacity:1;visibility:visible;}
.cc-panel{transform:translateY(110%);transition:transform .42s var(--sp3);}
.cc-panel.open{transform:translateY(0);}

/* Switcher - slide up */
#switcher{opacity:0;visibility:hidden;transform:translateY(100%);transition:opacity .3s var(--eo),transform .42s var(--sp3),visibility .3s;}
#switcher.open{opacity:1;visibility:visible;transform:translateY(0);}

/* Spotlight */
#spot{opacity:0;visibility:hidden;transform:translateY(-22px) scale(.97);transition:opacity .25s var(--eo),transform .3s var(--sp3),visibility .25s;}
#spot.open{opacity:1;visibility:visible;transform:none;}

/* Siri */
#siri{opacity:0;visibility:hidden;transform:translateY(50px) scale(.95);transition:opacity .3s var(--eo),transform .4s var(--sp2),visibility .3s;}
#siri.open{opacity:1;visibility:visible;transform:none;}

/* Dynamic island expand */
#island{transition:width .45s var(--sp2),height .45s var(--sp2),border-radius .45s var(--sp2);}
#island.expand{width:calc(100% - 24px)!important;height:76px!important;border-radius:22px!important;}
#islandContent{opacity:0;transition:opacity .18s .2s;}
#island.expand #islandContent{opacity:1;}

/* Lock fade */
#lock.hiding{animation:lkHide .35s var(--eo) forwards;}
@keyframes lkHide{to{opacity:0;transform:scale(1.06);}}

/* Passcode dots */
.pc-dot{transition:all .14s var(--sp2);}
.pc-dot.on{transform:scale(1.2);background:#fff!important;}

/* Phone keypad */
.kk{transition:transform .09s var(--sp2),background .09s;}
.kk:active{transform:scale(.86)!important;}

/* Volume HUD */
#volHud{transform:scale(.85);transition:opacity .22s,transform .28s var(--sp2);}
#volHud.show{transform:scale(1);}

/* Toast */
.mute-toast{transform:translateX(-50%) scale(.88) translateY(10px);transition:opacity .2s,transform .28s var(--sp2);}
.mute-toast.show{transform:translateX(-50%) scale(1) translateY(0);}

/* CC tiles */
.cc-tile{transition:transform .1s var(--sp2),background .15s,color .15s,opacity .15s;}
.cc-tile:active{transform:scale(.86);}

/* SW cards */
.sw-card{transition:transform .18s var(--sp2);}
.sw-card:active .sw-prev{transform:scale(.96);}
.sw-close-btn{transform:scale(0);opacity:0;transition:transform .18s var(--sp2),opacity .18s;}
.sw-card:hover .sw-close-btn,.sw-close-btn.vis{transform:scale(1);opacity:1;}

/* Calculator */
.cb{transition:transform .09s var(--sp2),opacity .09s,background .1s;}
.cb:active{transform:scale(.86);opacity:.7;}

/* Button press */
.btn-silent:active,.btn-vol-up:active,.btn-vol-dn:active,.btn-power:active{filter:brightness(1.5);}

/* Map card slide */
#mapCard{transition:transform .4s var(--sp3);}
#mapCard.show{transform:translateY(0)!important;}

/* Widget press */
.widget{transition:transform .12s var(--sp2),box-shadow .12s;}
.widget:active{transform:scale(.97);}

/* SF nav active */
.sf-fav{transition:transform .1s var(--sp2);}
.sf-fav:active{transform:scale(.88);}

/* Settings row */
.set-row:active{background:rgba(0,0,0,.06)!important;}

/* Scroll classes */
.scroll{-webkit-overflow-scrolling:touch;overflow-y:auto;}

/* Badge pop */
@keyframes badgePop{0%{transform:scale(0);}60%{transform:scale(1.3);}100%{transform:scale(1);}}
.badge{animation:badgePop .4s var(--sp2) .3s both;}

/* Lock particles */
@keyframes ptf{0%{transform:translateY(0) scale(1);opacity:.5;}100%{transform:translateY(-110vh) scale(.2);opacity:0;}}
.pt{position:absolute;background:rgba(255,255,255,.45);border-radius:50%;animation:ptf linear infinite;}

/* Typing */
@keyframes typ{0%,80%,100%{transform:scale(1);opacity:.4;}40%{transform:scale(1.5);opacity:1;}}